【C语言练习——打印水仙花数及其变形】

CSDN话题挑战赛第1期
活动详情地址:活动地址
参赛话题:大学学习月/季度总结
话题描述:对自己大学的月/季度学习的复盘及展望


水仙花数及其变形

  • 前言
  • 1、水仙花数
  • 2、变种水仙花数
    • 2.1 写法1
    • 2.2 写法2
    • 2.3 写法3
  • 总结

前言

本文主要是记录水仙花题目的练习,内容主要包括:

  • 水仙花数
  • 变种水仙花数

1、水仙花数

打印水仙花数
“水仙花数”是指一个n位数,其各位数字的n次方之和确好等于该数本身,如:,则153是一个“水仙花数”。

例如:

1531^35^33^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期
活动详情地址:活动地址

你可能感兴趣的:(C知识点的练习题,c语言,开发语言)