1.在屏幕上输出以下图案:
*
***
*****
*******
*********
***********
*************\\以此分界,以上为上半部分,以下为下半部分
***********
*********
*******
*****
***
*
代码如下:
#include<stdio.h>
#include<windows.h>
int main()
{
int i = 1;
\\图形的上半部分
for (; i <= 13; i += 2)
{
int j = 1;
for (; j <= i; j++)
{
printf("*");
}
printf("\n");
}
\\图形的下半部分
for (i=11; i >= 1; i-=2)
{
int j = 1;
for (; j <= i; j++)
{
printf("*");
}
printf("\n");
}
system("pause");
return 0;
}
2.求出0〜999之间的所有“水仙花数”并输出。
“水仙花数”是指一个三位数,其各位数字的立方和确好等于该数本身,如;153=1+5+3?,则153是一个“水仙花数”。
例如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。
要求0~999之间的水仙花数,总思路是设一个数 i ,要求 i 从0变到999。在计算 i是否是水仙花数时,要把 i 进行拆分,是里面999最大的数,而且是三位数。
比如 i 为153,要把153拆分成1,5,3。
再进行153 = 1^3 + 5^3 + 3^运算。
代码如下:
#include<stdio.h>
#include<windows.h>
#include<math.h>
int main()
{
int i = 0;
for (; i <= 999; i++)
{
int a, b, c;
a = i % 10;
b = (i / 10) % 10;
c = i / 100;
if (i == a*a*a + b*b*b + c*c*c)
{
printf("%d是水仙花数\n", i);
}
}
system("pause");
return 0;
}
3.求Sn=a+aa+aaa+aaaa+aaaaa的前5项之和,其中a是一个数字,
例如:2+22+222+2222+22222
思路是,先输入a。
要求a+aa+aaa+aaaa+aaaaa设一个循环即可
代码如下:
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<windows.h>
int main()
{
printf("计算sn=a+aa+aaa+aaaa+aaaaa\n");
int a;
printf("请输入a: ");
scanf("%d", &a);
int sn = 0;
int num = a;
int i = 1;
for (; i <= 5; i++)
{
sn += num;
num = num * 10 + a;
}
printf("sn=%d",sn);
system("pause");
return 0;
}