1 在屏幕上输出以下图案:
*
***
*****
*******
*********
***********
*************
***********
*********
*******
*****
***
*
***
*****
*******
*********
***********
*************
***********
*********
*******
*****
***
*
#define _CRT_SECURE_NO_WARNINGS ch
#include<stdio.h>
#include<Windows.h>
//在屏幕上输出以下图案:
// *
// ***
// *****
// *******
// *********
// ***********
//*************
// ***********
// *********
// *******
// *****
// ***
// *
int main(){
//先打印上半部分
int line = 7;
int i = 0;
for (i = 1; i <=line; i++){
//打印空格
int j = 0;
for (j = 0; j <line - i; j++){
printf(" ");
}
//打印*
for (j = 0; j <2*i-1; j++){
printf("*");
}
printf("\n");
}
//打印下半部分
for (i = 1; i <line; i++){
//打印空格
int j = 0;
for (j = 0; j <i; j++){
printf(" ");
}
//打印*
for (j = 0; j <2 *(line-1-i)+1; j++){//?公式想不到
printf("*");
}
printf("\n");
}
system("pause");
return 0;
}
运行结果:
2.求出0~999之间的所有“水仙花数”并输出。(要特别注意局部变量和全局变量的使用)
/*
在数论中,水仙花数(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。
*/
/*
在数论中,水仙花数(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。
*/
#define _CRT_SECURE_NO_WARNINGS ch
#include<stdio.h>
#include<Windows.h>
#include<math.h>
int main(){
int i = 0;
for (i = 0; i <1000; i++){
double num = 1;
int temp = i;
while (temp / 10){//先判断是几位数
num++;
temp = temp / 10;
}
temp = i;
int count = 0;
while (temp){//对每一位求对应次方之和
count = count +pow(temp%10, num);
temp = temp / 10;
}
if (count == i){
printf("%d ", i);
}
}
system("pause");
return 0;
}
运行结果:
3.
求Sn=a+aa+aaa+aaaa+aaaaa的前5项之和,其中a是一个数字,例如:2+22+222+2222+22222
#define _CRT_SECURE_NO_WARNINGS ch
#include<stdio.h>
#include<Windows.h>
#include<math.h>
//求Sn = a + aa + aaa + aaaa + aaaaa的前5项之和,其中a是一个数字,例如:2 + 22 + 222 + 2222 + 22222
int main(){
int a = 2;
int i = 1;
int sum = 0;
int temp = 0;
for (i = 0; i <5; i++){
temp = temp * 10 + a;//temp每次过来得到的是每一项的值
sum = sum+temp;//累加每一项的值
}
printf("%d ", sum);
system("pause");
return 0;
}
运行结果:
4.编写一个程序,它从标准输入读取C源代码,并验证所有的花括号都正确的成对出现。
#define _CRT_SECURE_NO_WARNINGS ch
#include<stdio.h>
#include<Windows.h>
#include<math.h>
//编写一个程序,它从标准输入读取C源代码,并验证所有的花括号都正确的成对出现。
int main(){
char ch = 0;
int count = 0;
while ((ch = getchar()) != EOF){//EOF--输入Ctrl+z结束输入
if ( '{'==ch){
count++;
}
else if (ch == '}'&&count == 0){//}}{{特殊情况
printf("不匹配!");
system("pause");
return 0;
}
else if ('}'==ch){
count--;
}
}
if (0 == count){
printf("匹配!");
}
else{
printf("不匹配!");
}
system("pause");
return 0;
}
运行结果:(三种情况测试用例)