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;
}
相关推荐
2401_841495646 分钟前
【自然语言处理】中文 n-gram 词模型
人工智能·python·算法·自然语言处理·n-gram·中文文本生成模型·kneser-ney平滑
San3027 分钟前
从零到一:彻底搞定面试高频算法——“列表转树”与“爬楼梯”全解析
javascript·算法·面试
F_D_Z33 分钟前
最长连续序列(Longest Consecutive Sequence)
数据结构·算法·leetcode
ss27334 分钟前
Java并发编程:DelayQueue延迟订单系统
java·python·算法
JHC00000036 分钟前
118. 杨辉三角
python·算法·面试
WolfGang0073211 小时前
代码随想录算法训练营Day50 | 拓扑排序、dijkstra(朴素版)
数据结构·算法
业精于勤的牙1 小时前
浅谈:算法中的斐波那契数(四)
算法
一直都在5721 小时前
数据结构入门:二叉排序树的删除算法
数据结构·算法
白云千载尽1 小时前
ego_planner算法的仿真环境(主要是ros)-算法的解耦实现.
算法·无人机·规划算法·后端优化·ego·ego_planner
hweiyu001 小时前
排序算法简介及分类
数据结构