题目:有 1、2、3、4 个数字,能组成多少个互
不相同且无重复数字的三位数?都是多少?1.程
序分析:可填在百位、十位、个位的数字都是
1、2、3、4。组成所有的排列后再去掉不满足条
件的排列。 2.程序源代码:
main()
{
int i,j,k;
printf("");
for(i=1;i<5;i++) /*以下为三重循环*/
for(j=1;j<5;j++)
for (k=1;k<5;k++)
{
if (i!=k&&i!=j&&j!=k) /* 确 保
i、j、k 三位互不相同*/
printf("%d,%d,%d",i,j,k);
}
}
题目:一个整数,它加上 100 后是一个完全平方
数,再加上 168 又是一个完全平方数,请问该数
是多少?1.程序分析:在 10 万以内判断,先将
该数加上 100 后再开方,再将该数加上 268 后再
开方,如果开方后的结果满足如下条件,即是结
果。请看具体分析:2.程序源代码:
#include "math.h"
main()
{
long int i,x,y,z;
for (i=1;i<100000;i++)
{ x=sqrt(i+100); /*x 为加上 100 后开方后
的结果*/
y=sqrt(i+268); /*y 为再加上 168 后开方
后的结果*/
if(x*x==i+100&&y*y==i+268)/*如果一个
数的平方根的平方等于该数,这说明此数是完全
平方数*/
printf("%ld",i);
}
}
题目:输入三个整数 x,y,z,请把这三个数由小
到大输出。
1.程序分析:我们想办法把最小的数放到 x 上,
先将 x 与 y 进行比较,如果 x>y 则将 x 与 y 的值
进行交换,然后再用 x 与 z 进行比较,如果 x>z
则将 x 与 z 的值进行交换,这样能使 x 最小。2.
程序源代码:
main()
{
int x,y,z,t;
scanf("%d%d%d",&x,&y,&z);
if (x>y)
{t=x;x=y;y=t;} /*交换 x,y 的值*/
if(x>z)
{t=z;z=x;x=t;}/*交换 x,z 的值*/
if(y>z)
{t=y;y=z;z=t;}/*交换 z,y 的值*/
printf("small to big: %d %d %d",x,y,z);
}
题目:用*号输出字母 C 的图案。
1.程序分析:可先用'*'号在纸上写出字母 C,再
分行输出。2.程序源代码:
#include "stdio.h"
main()
{
printf("Hello C-world!");
printf(" ****");
printf(" *");
printf(" * ");
printf(" ****");
}
题目:输出 9*9 口诀。1.程序分析:分行与列考
虑,共 9 行 9 列,i 控制行,j 控制列。
2.程序源代码:
#include "stdio.h"
main()
{
int i,j,result;
printf("");
for (i=1;i<10;i++)
{ for(j=1;j<10;j++)
{
result=i*j;
printf("%d*%d=%-3d",i,j,result);/*-3d
表示左对齐,占 3 位*/
}
printf("");/*每一行后换行*/
}
}
题目:判断 101-200 之间有多少个素数,并输出
所有素数。
1.程序分析:判断素数的方法:用一个数分别去
除 2 到 sqrt(这个数),如果能被整除,
则表明此数不是素数,反之是素数。
2.程序源代码:
#include "math.h"
main()
{
int m,i,k,h=0,leap=1;
printf("");
for(m=101;m<=200;m++)
{ k=sqrt(m+1);
for(i=2;i<=k;i++)
if(m%i==0)
{leap=0;break;}
if(leap) {printf("%-4d",m);h++;
if(h%10==0)
printf("");
}
leap=1;
}
printf("The total is %d",h);
}
题目:利用条件运算符的嵌套来完成此题:学习
成绩>=90 分的同学用 A 表示,60-89 分之间的用
B 表示,60 分以下的用 C 表示。1.程序分析:
(a>b)?a:b 这是条件运算符的基本例子。
2.程序源代码:
main()
{
int score;
char grade;
printf("please input a score");
scanf("%d",&score);
grade=score>=90?'A':(score>=60?'B':'C');
printf("%d belongs to %c",score,grade);
}
题目:输入两个正整数 m 和 n,求其最大公约数
和最小公倍数。
1.程序分析:利用辗除法。 2.程序源代码:
main()
{
int a,b,num1,num2,temp;
printf("please input two numbers:");
scanf("%d,%d",&num1,&num2);
if(num1
{ temp=num1;
num1=num2;
num2=temp;
}
a=num1;b=num2;
while(b!=0)/*利用辗除法,直到 b 为 0 为止*/
{
temp=a%b;
a=b;
b=temp;
}
printf("gongyueshu:%d",a);
printf("gongbeishu:%d",num1*num2/a);
)
题目:输入一行字符,分别统计出其中英文字母、
空格、数字和其它字符的个数。
1.程序分析:利用 while 语句,条件为输入的字符
不为''. 2.程序源代码:
#include "stdio.h"
main()
{char c;
int letters=0,space=0,digit=0,others=0;
printf("please input some characters");