1.在数论中,水仙花数(Narcissistic number)也称为自恋数、自幂数、阿姆斯壮数或阿姆斯特朗数(Armstrong number),是指一N位数,其各个数之N次方和等于该数。
例如153、370、371及407就是三位数的水仙花数,其各个数之立方和等于该数:
153 = 1^3 + 5^3 + 3^3。
370 = 3^3 + 7^3 + 0^3。
371 = 3^3 + 7^3 + 1^3。
407 = 4^3 + 0^3 + 7^3。
本题可用for循环(for(变量初始值;循环条件;循环一次后修改变量的值))加一个if选择语句(if(选择条件句)实现,具体代码如下(如有优化,请放入评论,虚心受教):
#define _CRT_SECURE_NO_WARNINGS
#include "stdio.h"
#include "stdlib.h"
#include "math.h"
#include "time.h"
#define NUM 10
void main()
{
int i = 0;
int num = 0;
for (i=100; i < 1000; ++i){
if (pow((i % 10), 3) + pow(((i % 100) / 10), 3) + pow((i / 100), 3)==i){
printf("%d\n", i);
}
}
system("pause");
}
2.求Sn=a+aa+aaa+aaaa+aaaaa的前5项之和,其中a是一个数字,
例如:2+22+222+2222+22222
从题目中我们可以看出这依旧是一个可使用for循环的程序,是一个累加的过程,中途累加两次,
以下是源代码:
#define _CRT_SECURE_NO_WARNINGS
#include "stdio.h"
#include "stdlib.h"
#include "math.h"
void main()
{
int a = 0;
int i = 0;
int sum = 0;
int num = 0;
printf("请输入一个a:\n");
scanf("%d", &a);
for (i = 0; i <=4; i++){
num += a*(pow(10, i));
sum += num;
}
printf("%d", sum);
system("pause");
}
3.在屏幕上输出以下图案:
*
*** ·
***** .
******* .
********* .
***********.
************* .
***********.
********* .
******* .
***** .
*** .
*
依旧是运用循环来实现,从一个*开始循环,循环每次递增两个,循环六次开始递减两个,直到剩一个,结束。源代码如下:
#define _CRT_SECURE_NO_WARNINGS
#include "stdio.h"
#include "stdlib.h"
#include "math.h"
void main()
{
int i, j;
for (i = 1; i <= 26; i += 2)
{
if (i <=13)
{
for (j = 0; j <= i; j++)
printf("*");
}
printf("\n");
if (i >13)
{
for (j = i+2; j < 26; j++)
printf("*");
}
printf("\n");
}
system("pause");
return 0;
}
今天结束,比心~