1.在屏幕上输出以下图案:
*
***
*****
*******
*********
***********
*************
***********
*********
*******
*****
***
*
#include<stdio.h>
#include<stdlib.h>
int main() {
int i, j;
for (i = 1; i <= 7; i++) {
for (j = 1; j <= 2 * i - 1; j++) {
printf("*");
}
printf("\n");
}
for (i = 6; i >= 1; i--) {
for (j = 1; j <= 2 * i - 1; j++) {
printf(" *");
}
printf("\n");
}
printf("\n");
system("pause");
return 0;
}
2.求出0~999之间的所有“水仙花数”并输出。
“水仙花数”是指一个三位数,其各位数字的立方和确好等于该数本身,如;153=1+5+3 ? ,则153是一个“水仙花数”。
在数论中,水仙花数(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。
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
int main() {
int i = 0;
int a, b, c;//一会用来求水仙花数的个位,十位,百位
int count = 0;
for (i = 100; i <= 999; i++) {
a = i / 100;
b = i / 10 % 10;
c = i % 10;
if (i == pow(a, 3) + pow(b, 3) + pow(c, 3)) {
printf("%4d", i);
}
}
printf("\n");
system("pause");
return 0;
}
3.求Sn = a + aa + aaa + aaaa + aaaaa的前5项之和,其中a是一个数字,
例如:2 + 22 + 222 + 2222 + 22222
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
int main() {
int n,a,i;
int sn = 0;
int k = 0;
printf("请输入一个数及要求他的前多少项:\n");
scanf("%d%d", &a, &n);
for (i = 1; i <= n; i++) {
k = k * 10 + a;
sn = sn + k;
}
printf("%d\n", sn);
system("pause");
return 0;
}