c语言经典100题,要过程

Python07

c语言经典100题,要过程,第1张

您好,c语言经典100题:

程序1】

题目:有1,2,3,4个数字,能组成多少个互不相同且无重复数字的三位数

都是多少

1.程序分析:可填在百位,十位,个位的数字都是1,2,3,4.组成所有的排列后再去

掉不满足条件的排列.

2.程序源代码:

main()

{

int

i,j,k

printf("\n")

for(i1i<5i++)

/*以下为三重循环*/

for(j1j<5j++)

for

(k1k<5k++)

{

if

(i!k&&i!j&&j!k)

/*确保i,j,k三位互不相同*/

printf("%d,%d,%d\n",i,j,k)

}

}

【程序2】

题目:企业发放的奖金根据利润提成.利润(i)低于或等于10万元时,奖金可提10%利润高

于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可可提

成7.5%20万到40万之间时,高于20万元的部分,可提成5%40万到60万之间时高于

40万元的部分,可提成3%60万到100万之间时,高于60万元的部分,可提成1.5%,高于

100万元时,超过100万元的部分按1%提成,从键盘输入当月利润i,求应发放奖金总数

1.程序分析:请利用数轴来分界,定位.注意定义时需把奖金定义成长整型.

2.程序源代码:

main()

{

long

int

i

int

bonus1,bonus2,bonus4,bonus6,bonus10,bonus

scanf("%ld",&i)

bonus1100000*0.1bonus2bonus1+100000*0.75

bonus4bonus2+200000*0.5

bonus6bonus4+200000*0.3

bonus10bonus6+400000*0.15

if(i<100000)

bonusi*0.1

else

if(i<200000)

bonusbonus1+(i-100000)*0.075

else

if(i<400000)

bonusbonus2+(i-200000)*0.05

else

if(i<600000)

bonusbonus4+(i-400000)*0.03

else

if(i<1000000)

bonusbonus6+(i-600000)*0.015

else

bonusbonus10+(i-1000000)*0.01

printf("bonus%d",bonus)

}

【程序3】

题目:一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少

1.程序分析:在10万以内判断,先将该数加上100后再开方,再将该数加上268后再开方,如果开方后

的结果满足如下条件,即是结果.请看具体分析:

2.程序源代码:

#include

"math.h"

main()

{

long

int

i,x,y,z

for

(i1i2)/*如果是闰年且月份大于2,总天数应该加一天*/

sum++

printf("it

is

the

%dth

day.",sum)}

【程序4】

题目:输入某年某月某日,判断这一天是这一年的第几天?

1.程序分析:以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊

情况,闰年且输入月份大于3时需考虑多加一天。

2.程序源代码:

main()

{

int

day,month,year,sum,leap

printf("\nplease

input

year,month,day\n")

scanf("%d,%d,%d",&year,&month,&day)

switch(month)/*先计算某月以前月份的总天数*/

{

case

1:sum0break

case

2:sum31break

case

3:sum59break

case

4:sum90break

case

5:sum120break

case

6:sum151break

case

7:sum181break

case

8:sum212break

case

9:sum243break

case

10:sum273break

case

11:sum304break

case

12:sum334break

default:printf("data

error")break

}

sumsum+day

/*再加上某天的天数*/

if(year%4000||(year%40&&year%100!0))/*判断是不是闰年*/

leap1

else

leap0

if(leap1&&month>2)/*如果是闰年且月份大于2,总天数应该加一天*/

sum++

printf("It

is

the

%dth

day.",sum)}

【程序5】

题目:输入三个整数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)

{txxyyt}

/*交换x,y的值*/

if(x>z)

{tzzxxt}/*交换x,z的值*/

if(y>z)

{tyyzzt}/*交换z,y的值*/

printf("small

to

big:

%d

%d

%d\n",x,y,z)

}

【程序6】

题目:用*号输出字母c的图案.

1.程序分析:可先用'*'号在纸上写出字母c,再分行输出.

2.程序源代码:

#include

"stdio.h"

main()

{

printf("hello

c-world!\n")

printf("

****\n")

printf("

*\n")

printf("

*

\n")

printf("

****\n")

}

【程序7】

题目:输出特殊图案,请在c环境中运行,看一看,very

beautiful!

1.程序分析:字符共有256个.不同字符,图形不一样.

2.程序源代码:

#include

"stdio.h"

main()

{

char

a176,b219

printf("%c%c%c%c%c\n",b,a,a,a,b)

printf("%c%c%c%c%c\n",a,b,a,b,a)

printf("%c%c%c%c%c\n",a,a,b,a,a)

printf("%c%c%c%c%c\n",a,b,a,b,a)

printf("%c%c%c%c%c\n",b,a,a,a,b)}

【程序8】

题目:输出9*9口诀.

1.程序分析:分行与列考虑,共9行9列,i控制行,j控制列.

2.程序源代码:

#include

"stdio.h"

main()

{

int

i,j,result

printf("\n")

for

(i1i<10i++)

{

for(j1j<10j++)

{

resulti*j

printf("%d*%d%-3d",i,j,result)/*-3d表示左对齐,占3位*/

}

printf("\n")/*每一行后换行*/

}

}

【程序9】

题目:要求输出国际象棋棋盘.

1.程序分析:用i控制行,j来控制列,根据i+j的和的变化来控制输出黑方格,还是白方格.

2.程序源代码:

#include

"stdio.h"

main()

{

int

i,j

for(i0i<8i++)

{

for(j0j<8j++)

if((i+j)%20)

printf("%c%c",219,219)

else

printf("

")

printf("\n")

}

}

【程序10】

题目:打印楼梯,同时在楼梯上方打印两个笑脸.

1.程序分析:用i控制行,j来控制列,j根据i的变化来控制输出黑方格的个数.

2.程序源代码:

#include

"stdio.h"

main()

{

int

i,j

printf("\1\1\n")/*输出两个笑脸*/

for(i1i<11i++)

{

for(j1j<ij++)

printf("%c%c",219,219)

printf("\n")

}

}

【程序11】

题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月

后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少

1.程序分析:

兔子的规律为数列1,1,2,3,5,8,13,21....

2.程序源代码:

main()

{

long

f1,f2

int

i

f1f21

for(i1i<20i++)

{

printf("%12ld

%12ld",f1,f2)

if(i%20)

printf("\n")/*控制输出,每行四个*/

f1f1+f2

/*前两个月加起来赋值给第三个月*/

f2f1+f2

/*前两个月加起来赋值给第三个月*/

}

}

【程序12】

题目:判断101-200之间有多少个素数,并输出所有素数.

1.程序分析:判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,

则表明此数不是素数,反之是素数.

2.程序源代码:

#include

"math.h"

main()

{

int

m,i,k,h0,leap1

printf("\n")

for(m101m<200m++)

{

ksqrt(m+1)

for(i2i<ki++)

if(m%i0)

{leap0break}

if(leap)

{printf("%-4d",m)h++

if(h%100)

printf("\n")

}

leap1

}

printf("\nthe

total

is

%d",h)

}

1.打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数本身。例如,153是一个“水仙花数”,因为153=1^3+5^3+3^3。

#include

#include

int main()

{

int bai_wei,shi_wei,ge_wei,i,sum=0

for(i=100i<1000i++)

{

bai_wei=i/100

shi_wei=(i%100)/10

ge_wei=i%10

if(i==pow(bai_wei,3)+pow(shi_wei,3)+pow(ge_wei,3))

{

printf("%d ",i)

sum++

if(sum%5==0)

printf(" ")

}

}

printf(" ")

return 0

}

2.请输入任意两个整数x和y,求其最大公约数和最小公倍数。

#include

int main()

{

int x,y,min,max,i

printf("请输入任意两个整数:")

scanf("%d%d",&x,&y)

min=x>y?y:x

max=x>y?x:y

for(i=mini>0i--)

if(x%i==0&&y%i==0)

{

printf("这两个整数的最大公约数为:%d ",i)

break

}

for(i=maxi<=x*yi++)

if(i%x==0&&i%y==0)

{

printf("这两个整数的最小公倍数为:%d ",i)

break

}

return 0

}

3.输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。

#include

#include

#define N 50

int main()

{

int sum1=0,sum2=0,sum3=0,sum4,i=0

char str[N]

printf("请输入一串字符串:")

scanf("%s",str)

for(i=0i<strlen(str)i++) p=""></strlen(str)i++)>

{

if((str[i]>='a'&&str[i]='A'&&str[i]<='Z'))

sum1++

if(str[i]==' ')

sum2++

if(str[i]>='0'&&str[i]<='9')

sum3++

}

sum4=strlen(str)-sum1-sum2-sum3

printf("英文字母的个数:%d ",sum1)

printf("空格的个数:%d ",sum2)

printf("数字的个数:%d ",sum3)

printf("其他符号的个数:%d ",sum4)

return 0

}

4.求s=a+aa+aaa+aaaa+aa…a的值,其中a是一个数字。例如2+22+222+2222+22222(此时共有5个数相加),几个数相加有键盘控制。

#include

#include

int main()

{

int a,n,s=0,i,x=0,y=0

printf("请输入整数a的值:")

scanf("%d",&a)

printf("请输入相加的个数n:")

scanf("%d",&n)

for(i=0i<ni++) p=""></ni++)>

{

x=y+2*pow(10,i)

y=x

s=s+x

}

printf("s=%d ",s)

return 0

}

5.一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3。编程找出1000以内的所有完数。

#include

int main()

{

int sum=0,i,j

printf("在1000以内的完数有:")

for(i=2i<=1000i++)

{

for(j=1j<ij++) p=""></ij++)>

if(i%j==0)

sum=sum+j

if(sum==i)

printf("%d ",i)

sum=0

}

printf(" ")

return 0

}

6.输入一个不多于5位的正整数,要求:1、求它是几位数;2、逆序打印出个位数字。

#include

int pows(int a,int n)

{

int sum=1,i

for(i=0i<ni++) p=""></ni++)>

sum=sum*a

return sum

}

int main()

{

int n,i,k,x

printf("n=")

scanf("%d",&n)

for(i=1i<6i++)

if(n/pows(10,i)==0)

{

printf("%d ",i)

k=i

break

}

for(i=0i<ki++) p=""></ki++)>

{

x=n/pows(10,i)%10

printf("%d",x)

}

printf(" ")

return 0

}

7.输入一个5位数,判断它是不是回文数。即12321是回文数,个位与万位相同,十位与千位相同。

#include

int main()

{

int n,a[5],i=0

printf("请输入一个5位数:")

scanf("%d",&n)

while(n!=0)

{

a[i]=n%10

n=n/10

i++

}

if(a[0]==a[4]&&a[1]==a[3])

printf("这个数是回文数 ")

else

printf("这个数不是回文数 ")

return 0

}

8.利用递归算法,将所输入的5个字符,以相反顺序打印出来。

#include

void digui(char a[],int n)

{

if(n==1)

printf("%c",a[0])

else

{

printf("%c",a[n-1])

digui(a,n-1)

}

}

int main()

{

char str[5]

printf("请输入5个字符:")

scanf("%s",str)

digui(str,5)

printf(" ")

return 0

}

9.有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13…球出这个序列的前20项之和。

#include

int main()

{

int i,a=1,b=1

float sum=0.0

for(i=1i<=20i++)

{

sum=sum+(float)(a+i)/b

b=a+i

a=i

}

printf("sum=%f ",sum)

return 0

}

10.利用递归算法求5!。

#include

int digui(int n)

{

if(n==1)

return 1

else

return n*digui(n-1)

}

int main()

{

int n,sum

printf("n:")

scanf("%d",&n)

sum=digui(n)

printf("sum=%d ",sum)

return 0

}

选择题

1.在深度为5的满二叉树叶中,叶子结点的个数为( )。

A.32

B.31

C.16

D.15

2.软件生命周期中,花费最多的阶段是( )。

A.详细设计

B.软件编码

C.软件测试

D.软件维护

3.视图设计一般有3种设计次序,下列不属于视图设计次序的是( )。

A.自顶而下

B.由内向外

C.由外向内

D.自底向上

4.下列数据结构中,能用二分法进行查找的是( )。

A.顺序存储的有序线性表

B.结性链表

C.二叉链表

D.有序线性链表

5.以下叙述中错误的是( )。

A.对于double类型数组,不可以直接用数组名对数组进行整体输入或输出

B.数组名代表的是数组所占存储区的首地址,其值不可改变

C.当程序执行中,数组元素的下标超出所定义的下标范围时,系统将给出“下标越界”的出错信息

D.可以通过赋初值的方式确定数组元素的个数

6.以下只有在使用时才为该类型变量分配内存的存储类型说明是( )。

A.auto和static

B.auto和register

C.register和static

D.extern和register

7.下列可作为C语言赋值的语句的是( )。

A.x一3,y=5

B.a=b=6

C.i--

D.a,c

8.若整型变量a、b、c、d中的值依次为2、2、3、4,则条件表达式aA.1

B.2

C.3

D.4

9.下列叙述中错误的是( )。

A.线性表是由n个元素组成的一个有限序列

B.线性表是一种线性结构

C.线性表的所有结点有且仅有一个前件和后件

D.线性表可以是空表

10.以下程序执行后sum的值是( )。

main()

{ int i,sum

for(i=1i<6i++)sum+=i:

printf("1%d\n",sum):

}

A.15

B.14

C.不确定

D.0

11.设j为Int型变量,则下面for循环语句的执行结果是( )。

for(j=10j>3j--)

{ if(j%3)j--

--j--j

printf("%d",j)

}

A.6 3

B.7 4

C.6 2

D.7 3

12.表示关系X<=Y<=Z的C语言表达式为( )。

A.(X<=Y)&&(Y<=Z)

B.(X<=Y)AND(Y<=Z)

C.(X<=Y<=Z)

D.(X<一Y)&(Y<一Z)

13.设有如下定义:

int arr[]={6,7,8,9,10)

int*ptr:

ptr=arr

*(ptr2)=2

printf("%d,%d\n",*ptr,*(ptr2)):

则下列程序段的输出结果为( )。

A.8,10

B.6,8

C.7,9

D.6,2

14.设有定义语句:

int x[-6]={2,4,6,8,5,7),*p=X,i

要求依次输出X数组6个元素中的值,不能完成此操作的语句是( )。

A.for(i=0i<6i++)printf("%2d",*(p++))

B.for(i=0i<6i++)printf("%2d",*(pq-i))

C.for(i=0i<6i++)printf("%2d",*p++)

D.for(i=0i<6i++)printf("%2d",*(p)++)

15.数字字符0的ASCII值为48,运行以下程序的输出结果是( )。

main()

( char a=’1’,b=’2’

printf("%C,",b++)printf("%d\n",b—a)}

A.3,2

B.50,2

C.2,2

D.2,50

16.设有如下定义:

int(*ptr)()

则以下叙述中正确的是( )。

A.ptr是指向一维组数的指针变量

B.ptr是指向int型数据的指针变量

C.ptr是指向函数的指针,该函数返回一个int型数据

D.ptr是一个函数名,该函数的返回值是指int型数据的指针

17.设有定义的语句:“char c1=92,c2=92”,则以下表达式中的值为零的是( )。

A.c1^c2

B.c1&c2

C.~c2

D.c1 | c2

18.以下程序的输出结果是( )。

void fun(int*a,int i,int i)

{int t

if(i { t=a[i[a[i]=a[j]a[j]一t

i++j--

fun(a,i,j)

}

}

main()

{ int K[]={2,6,1,8},i

fun(x,0,3)

for(i=0i<1i++)printf("%2d",x[i])

printf("\n")

}

A.1,2,6,8

B.8,6,2,1

C.8,1,6,2

D.8,6,1,2

19.有以下程序:

main()

{int i,j

for(j=10j<11j++)

{ for(i=9i if(!(j%i))break

if(i==j-1)

printf("%d",j)

}

}

输出结果是( )。

A.11

B.10

C.9

D.10 11

11.设j为Int型变量,则下面for循环语句的执行结果是( )。

for(j=10j>3j--)

{ if(j%3)j--

--j--j

printf("%d",j)

}

A.6 3

B.7 4

C.6 2

D.7 3

12.表示关系X<=Y<=Z的C语言表达式为( )。

A.(X<=Y)&&(Y<=Z)

B.(X<=Y)AND(Y<=Z)

C.(X<=Y<=Z)

D.(X<一Y)&(Y<一Z)

13.设有如下定义:

int arr[]={6,7,8,9,10)

int*ptr:

ptr=arr

*(ptr2)=2

printf("%d,%d\n",*ptr,*(ptr2)):

则下列程序段的输出结果为( )。

A.8,10

B.6,8

C.7,9

D.6,2

14.设有定义语句:

int x[-6]={2,4,6,8,5,7),*p=X,i

要求依次输出X数组6个元素中的值,不能完成此操作的语句是( )。

A.for(i=0i<6i++)printf("%2d",*(p++))

B.for(i=0i<6i++)printf("%2d",*(pq-i))

C.for(i=0i<6i++)printf("%2d",*p++)

D.for(i=0i<6i++)printf("%2d",*(p)++)

15.数字字符0的ASCII值为48,运行以下程序的输出结果是( )。

main()

( char a=’1’,b=’2’

printf("%C,",b++)printf("%d\n",b—a)}

A.3,2

B.50,2

C.2,2

D.2,50

16.设有如下定义:

int(*ptr)()

则以下叙述中正确的是( )。

A.ptr是指向一维组数的指针变量

B.ptr是指向int型数据的指针变量

C.ptr是指向函数的指针,该函数返回一个int型数据

D.ptr是一个函数名,该函数的返回值是指int型数据的指针

17.设有定义的语句:“char c1=92,c2=92”,则以下表达式中的值为零的是( )。

A.c1^c2

B.c1&c2

C.~c2

D.c1 | c2

18.以下程序的输出结果是( )。

void fun(int*a,int i,int i)

{int t

if(i { t=a[i[a[i]=a[j]a[j]一t

i++j--

fun(a,i,j)

}

}

main()

{ int K[]={2,6,1,8},i

fun(x,0,3)

for(i=0i<1i++)printf("%2d",x[i])

printf("\n")

}

A.1,2,6,8

B.8,6,2,1

C.8,1,6,2

D.8,6,1,2

19.有以下程序:

main()

{int i,j

for(j=10j<11j++)

{ for(i=9i if(!(j%i))break

if(i==j-1)

printf("%d",j)

}

}

输出结果是( )。

A.11

B.10

C.9

D.10 11

20.有以下程序.

#include

main()

{ char c1,c2,c3,c4,c5,c6

scanf("%c%c%c%c",&c1,&c2,&c3,&c4)

c5=getchar()c6=getchar()

putchar(c1)putchar(c2)

printf("%c%c\n",c5,c6)

}

程序运行后,若从键盘输入(从第l列开始)

123<回车>

45678<回车>

则输出结果是( )。

A.1267

B.1256

C.1278

D.1245