[牛客]BC38 变种水仙花

BC38

判断是不是自幂数(水仙花数)

题目描述

参考代码:

c 复制代码
//直接暴力求解
//先计算某个数有几位 然后分别拿到每一位进行计算
#include<math.h>

//计算num是几位数
int numOfDigit(int num)
{
	int count = 0;
	//153 1     15  2    1 3
	while (num > 0)
	{
		count++;
		num /= 10;
	}
	return count;
}

//拿到num的每一位数求和 判断是不是自幂数
int isSelfPower(int num)
{
	int sum = 0;//求和
	int count = numOfDigit(num);//num是几位数
	int flag = num;//用于保存初始num的值

	//1234  4       123   3       12 2     1 1
	while (num > 0)
	{
	    //pow的返回值类型是double
		sum += (int)pow(num % 10, count);
		num /= 10;
	}
	return sum == flag;
}

int main()
{
	int i = 0;
	for (i = 1; i <= 100000; i++)
	{
		if (isSelfPower(i))
			printf("%d ", i);
	}
	return 0;
}

BC38 变种水仙花

题目链接

点我做题

解析

注意下面的sum = 0

每次循环都要把sum置为0 否则sum会保持上次计算的结果

12345:

1(12345/10000) 2345(12345%10000)

12(12345/1000) 345(12345%1000)

123(12345/100) 45(12345%100)

1234(12345/10) 5(12345%10)

参考代码:

c 复制代码
#include <math.h>
#include <stdio.h>

int main() {
    int i = 0;
    int j = 0;
    int sum = 0;
    for (i = 10000; i <= 99999; i++) {
        sum = 0;
        for (j = 1; j <= 4; j++) {
            int k = pow(10, j);
            //sum+=(i/k)*(i%k);
            sum += (i / (int)pow(10, j)) * (i % (int)pow(10, j));
        }
        if(sum == i)
        printf("%d ",i);
    }
    return 0;
}
相关推荐
小雅痞6 小时前
[Java][Leetcode middle] 167. 两数之和 II - 输入有序数组
java·算法·leetcode
CN-Dust6 小时前
【C++】输入cin例题专题
java·c++·算法
数模竞赛Paid answer7 小时前
2025年MathorCup数学建模A题汽车风阻预测解题文档与程序
算法·数学建模·mathorcup
Old Uncle Tom13 小时前
OpenClaw 记忆系统 -- 记忆预加载
java·数据结构·算法·agent
会编程的土豆13 小时前
洛谷题单入门1 顺序结构
数据结构·算法·golang
生信碱移13 小时前
PACells:这个方法可以鉴定疾病/预后相关的重要细胞亚群,作者提供的代码流程可以学习起来了,甚至兼容转录组与 ATAC 两种数据类型!
人工智能·学习·算法·机器学习·数据挖掘·数据分析·r语言
智者知已应修善业13 小时前
【51单片机中的打飞机设计】2023-8-25
c++·经验分享·笔记·算法·51单片机
智者知已应修善业16 小时前
【51单片机按键调节占空比3位数码管显示】2023-8-24
c++·经验分享·笔记·算法·51单片机
.54816 小时前
## Sorting(排序算法)
python·算法·排序算法
wuweijianlove17 小时前
算法的平均复杂度建模与性能回归分析的技术7
算法·数据挖掘·回归