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;
}
相关推荐
is081540 分钟前
STM32的 syscalls.c 和 sysmem.c
c语言·stm32·嵌入式硬件
张人玉1 小时前
C# 常量与变量
java·算法·c#
学不动CV了1 小时前
数据结构---链表结构体、指针深入理解(三)
c语言·arm开发·数据结构·stm32·单片机·链表
weixin_446122462 小时前
LinkedList剖析
算法
百年孤独_3 小时前
LeetCode 算法题解:链表与二叉树相关问题 打打卡
算法·leetcode·链表
我爱C编程3 小时前
基于拓扑结构检测的LDPC稀疏校验矩阵高阶环检测算法matlab仿真
算法·matlab·矩阵·ldpc·环检测
算法_小学生3 小时前
LeetCode 75. 颜色分类(荷兰国旗问题)
算法·leetcode·职场和发展
运器1233 小时前
【一起来学AI大模型】算法核心:数组/哈希表/树/排序/动态规划(LeetCode精练)
开发语言·人工智能·python·算法·ai·散列表·ai编程
算法_小学生3 小时前
LeetCode 287. 寻找重复数(不修改数组 + O(1) 空间)
数据结构·算法·leetcode
岁忧3 小时前
(LeetCode 每日一题) 1865. 找出和为指定值的下标对 (哈希表)
java·c++·算法·leetcode·go·散列表