CSDN话题挑战赛第1期
活动详情地址:活动地址
参赛话题:大学学习月/季度总结
话题描述:对自己大学的月/季度学习的复盘及展望
前言
本文主要是记录水仙花题目的练习,内容主要包括:
- 水仙花数
- 变种水仙花数
1、水仙花数
打印水仙花数
“水仙花数”是指一个n位数,其各位数字的n次方之和确好等于该数本身,如:,则153是一个“水仙花数”。
例如:
153=1^3+5^3+3^3
题目:求出0~100000之间的所有“水仙花数”并输出。
int main()
{
int i = 0;
for (int i = 0; i <= 100000; i++)
{
//判断数字有几位
int n = 1;
int tmp = i;
while (tmp /= 10)
{
n++;
}
tmp = i;
//计算每一位的n次方之和
int sum = 0;
while (tmp)
{
sum += (int)pow(tmp % 10, n);
tmp /= 10;
}
//比较大小是否相等
if (sum == i)
{
printf("%d ", i);
}
}
return 0;
}
2、变种水仙花数
描述
变种水仙花数 - Lily Number:把任意的数字,从中间拆分成两个数字,比如1461 可以拆分成(1和461),(14和61),(146和1),如果所有拆分后的乘积之和等于自身,则是一个Lily Number。
例如:
655 = 6 * 55 + 65 * 5
1461 = 1*461 + 14*61 + 146*1
题目:求出 5位数中的所有 Lily Number。
输入描述:
无
输出描述:
一行,5位数中的所有 Lily Number,每两个数之间间隔一个空格。
2.1 写法1
自己写的比较啰嗦,但是也实现了题目的要求
int main()
{
int a = 0;
int b = 0;
int c = 0;
int d = 0;
for (int i = 10000; i < 99999; i++)
{
a = (i / 10000)* (i % 10000);
b = (i / 1000)* (i % 1000);
c = (i / 100)* (i % 100);
d = (i / 10)* (i % 10);
if (i == (a + b + c + d))
{
printf("%d ", i);
}
}
return 0;
}
2.2 写法2
int main()
{
int i;
for(i=10000;i<100000;i++)
{
if(i==((i/10000)*(i%10000))+((i/1000)*(i%1000))+((i/100)*(i%100))+((i/10)*(i%10)))
printf("%d ",i);
}
}
2.3 写法3
int main()
{
int i = 0;
for(i=10000; i<=99999; i++)
{
//判断i是否为lily number
int j = 10;
int sum = 0;
int tmp = i;
for(j=10; j<=10000; j*=10)
{
sum += (tmp%j)*(tmp/j);
}
if(sum == i)
printf("%d ", i);
}
return 0;
}
总结
感受就是自己的练习量非常少,编程思路不活跃,还需要多练习。
自己写的代码很罗嗦,不简洁,牛客上写完题目后还是要多看看别人的思路,学习别人的代码。
CSDN话题挑战赛第1期
活动详情地址:活动地址