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;
}
相关推荐
西猫雷婶几秒前
python学智能算法(三十一)|SVM-Slater条件理解
人工智能·python·算法·机器学习·支持向量机
仪器科学与传感技术博士6 分钟前
python:以支持向量机(SVM)为例,通过调整正则化参数C和核函数类型来控制欠拟合和过拟合
开发语言·python·算法·机器学习·支持向量机·过拟合·欠拟合
科大饭桶8 分钟前
C++入门自学Day5-- C/C++内存管理(续)
c语言·开发语言·c++
一只乔哇噻10 分钟前
Java,八股,cv,算法——双非研0四修之路day24
java·开发语言·经验分享·学习·算法
ZLRRLZ40 分钟前
【数据结构】哈希表实现
数据结构·c++·散列表
codelancera1 小时前
算法-广度优先遍历-判断迷宫是否有出口
算法·宽度优先
kokunka1 小时前
【数据结构】队列的顺序存储与链式存储(C语言版)
c语言·数据结构·算法
Zzzzmo_1 小时前
数据结构-双链表
c语言·数据结构·链表
图先1 小时前
数据结构中使用到的C语言
c语言·数据结构
zhurui_xiaozhuzaizai2 小时前
多向量检索:lanchain,dashvector,milvus,vestorsearch,MUVERA
人工智能·算法·机器学习·全文检索·milvus