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

介绍水仙花数:

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

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

步骤:

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

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

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

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

cpp 复制代码
int cube(int num)
{
	return num * num * num;
}

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

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

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

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

cpp 复制代码
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;
}

完整的代码如下

cpp 复制代码
#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;
}
相关推荐
三体世界17 分钟前
Linux --TCP协议实现简单的网络通信(中英翻译)
linux·c语言·开发语言·网络·c++·windows·tcp/ip
csdn_aspnet40 分钟前
C++ 检查一条线是否与圆接触或相交(Check if a line touches or intersects a circle)
c++·算法
Java实践笔记1 小时前
40亿QQ号,只有1G内存,怎么存储和去重?
算法·面试·腾讯
怀旧,1 小时前
【C语言】C语言经典小游戏:贪吃蛇(下)
c语言·开发语言·数据结构
Musennn1 小时前
leetcode93.复原IP地址:回溯算法中段控制与前导零处理的深度解析
java·数据结构·算法·leetcode
爱coding的橙子1 小时前
每日算法刷题计划Day20 6.2:leetcode二分答案3道题,用时1h20min
算法·leetcode·职场和发展
CodeWithMe2 小时前
【C/C++】面试常考题目
c语言·c++·面试
子豪-中国机器人2 小时前
2025年5月18日蓝桥stema省选拔赛编程题答案解析
c++·算法·数学建模
极光雨雨2 小时前
【算法】回溯法
算法
君鼎2 小时前
排序算法——详解
数据结构·算法·排序算法