当前位置: 首页 > article >正文

C语言小任务——寻找水仙花数

介绍水仙花数:

首先,它是一个3 位数,而且它的每个数位上的数字的 3次幂之和等于它本身

例如153=1^3+5^3+3^3=1+125+27

步骤:

第一步:分离出这个三位数的三个数字

void getnum(int num , int* arr)
{
	int i = 0;
	for (i = 0; i < 3; i++)
	{
		arr[2-i] = num % 10;
		num /= 10;
	}
}

有一点务必要注意,当我们要对主函数中的变量进行改变的时候,一定要传入该变量的地址,否则,由于作用域有限,改变只能在子函数中有效,无法影响在主函数中变量的值 

第二步:计算数字各个位置的三次方

int cube(int num)
{
	return num * num * num;
}

第三步,计算各个三次方之和

int sumcube(int *arr)
{
    int sum = 0;
    int i = 0;
    for (i = 0; i < 3; i++)
    {
        sum += cube(arr[i]);
    }
    return sum;
}

第三步:判断是否和原数字相等(在住函数中做逻辑判断)

我们一般是,子函数中执行功能,主函数中执行逻辑判断

int main()
{
	int i = 0;
	int arr[3] = {9,9,9};
	for (i = 100; i < 1000; i++)
	{
		getnum(i, arr);
		if (i ==sumcube(arr)) 
		{
			printf("%d\n", i);
		}
	}

	return 0;
}

完整的代码如下

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<string.h>
#include<windows.h>
#include <stdlib.h>
#include <time.h> 
#include <math.h>
void getnum(int num , int* arr)
{
	int i = 0;
	for (i = 0; i < 3; i++)
	{
		arr[2-i] = num % 10;
		num /= 10;
	}
}

int cube(int num)
{
	return num * num * num;
}
int sumcube(int *arr)
{
	int sum = 0;
	int i = 0;
	for (i = 0; i < 3; i++)
	{
		sum += cube(arr[i]);
	}
	return sum;
}
int main()
{
	int i = 0;
	int arr[3] = {9,9,9};
	for (i = 100; i < 1000; i++)
	{
		getnum(i, arr);
		if (i ==sumcube(arr)) 
		{
			printf("%d\n", i);
		}
	}

	return 0;
}


http://www.kler.cn/a/516474.html

相关文章:

  • 19_PlayerPres持久化_创建角色窗口
  • k8s namespace绑定节点
  • 在 C++ 中实现调试日志输出
  • 基于单片机的智能台灯设计
  • springboot基于微信小程序的商城系统
  • Python的进程和线程
  • springboot基于微信小程序的商城系统
  • CPU中断机制
  • Ubuntu 24.04 LTS 通过 docker desktop 安装 seafile 搭建个人网盘
  • 分词器的词表大小以及如果分词器的词表比模型的词表大,那么模型的嵌入矩阵需要被调整以适应新的词表大小。
  • MySQL命令及用法(精华版)
  • 接口 V2 完善:基于责任链模式、Canal 监听 Binlog 实现数据库、缓存的库存最终一致性
  • 2024 行远自迩,笃行不怠
  • Geek Uninstaller,绿色免安装轻量的应用卸载工具!
  • 微软预测 AI 2025,AI Agents 重塑工作形式
  • 细节增强卷积DEConv详解及代码复现
  • 基于java的客户信息管理系统
  • Kafka面试题----Kafka中的Producer、Broker、Consumer以及Topic的概念
  • Python 快速下载依赖
  • 激光三角测量法精度计算
  • 为AI聊天工具添加一个知识系统 之65 详细设计 之6 变形机器人及伺服跟随
  • 单片机-STM32 IIC通信(OLED屏幕)(十一)
  • python-leetcode-随机链表的复制
  • 编写0号中断的处理程序
  • 【博客之星】年度总结:在云影与墨香中探寻成长的足迹
  • 牛客周赛 Round 77 A-C