1. 在屏幕上输出菱形
#include <stdio.h>
#include <stdlib.h>
int main() {
int row = 13;
int col = 13;
for (int i = 1; i <= row; i++) {
if (i < (row / 2) + 1) {
for (int j = 1; j < col; j++) {
if (j >= (col + 1) / 2 - (i - 1) &&
j <= (col + 1) / 2 + (i - 1)) {
printf("*");
}
else {
printf(" ");
}
}
}
else {
for (int j = 1; j <= col; j++) {
if (j >= (col + 1) / 2 - (row - i) &&
j <= (col + 1) / 2 + (row - i)) {
printf("*");
}
else {
printf(" ");
}
}
}
printf("\n");
}
system("pause");
return 0;
}
2. 求出0~100000之间的所有“水仙花数”并输出。
“水仙花数”是指一个n位数,其各位数字的n次方之和确好等于该数本身,如:153=1^3+5^3+3^3,则153是一个“水仙花数”。
//求出0~100000之间的所有“水仙花数”
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
int main() {
int i = 0;
printf("0~100000之间的水仙花数有:\n");
for (i = 0; i < 100000; i++) {
int a = i % 10;
int b = (i / 10) % 10;
int c = (i / 100) % 10;
int d = (i / 1000) % 10;
int e = (i / 10000) % 10;
if (i < 10) {
printf("%d\n", i);
}
else if ((10 <= i) && (i < 100) ) {
if (pow(a, 2) + pow(b, 2) + pow(c, 2) + pow(d, 2) + pow(e, 2) == i) {
printf("%d\n", i);
}
}
else if ((100 <= i) && (i < 1000)) {
if (pow(a, 3) + pow(b, 3) + pow(c, 3) + pow(d, 3) + pow(e, 3) == i) {
printf("%d\n", i);
}
}
else if ((1000 <= i) && (i < 10000)) {
if (pow(a, 4) + pow(b, 4) + pow(c, 4) + pow(d, 4) + pow(e, 4) == i) {
printf("%d\n", i);
}
}
else if ((10000 <= i) && (i < 100000)) {
if (pow(a, 5) + pow(b, 5) + pow(c, 5) + pow(d, 5) + pow(e, 5) == i) {
printf("%d\n", i);
}
}
}
system("pause");
return 0;
}
3. 求Sn=a+aa+aaa+aaaa+aaaaa的前5项之和,其中a是一个数字
//求Sn=a+aa+aaa+aaaa+aaaaa的前5项之和,其中a是一个数字
#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <stdlib.h>
int main() {
printf("请输入一个个位数:\n");
int a = 0;
scanf("%d", &a);
int b = a * 10 + a;
int c = b * 10 + a;
int d = c * 10 + a;
int e = d * 10 + a;
int Sn = a + b + c + d + e;
printf("Sn = %d\n", Sn);
system("pause");
return 0;
}

被折叠的 条评论
为什么被折叠?



