C语言编程练习试题绝对经典Word文档格式.docx
- 文档编号:22565660
- 上传时间:2023-02-04
- 格式:DOCX
- 页数:40
- 大小:37.46KB
C语言编程练习试题绝对经典Word文档格式.docx
《C语言编程练习试题绝对经典Word文档格式.docx》由会员分享,可在线阅读,更多相关《C语言编程练习试题绝对经典Word文档格式.docx(40页珍藏版)》请在冰豆网上搜索。
库函数后使用,函数说明为
doublesin<
doublex>
编写一个函数,使给定的一个二维数组<
N×
N>
行列互换<
3>
。
从键盘中输入一个不超过40个字符的字符串,再输入一个位数,删除对应位数的字符,然后输出删除指定字符后的字符串
要求:
用puts输出指示信息
2>
用gets接收字符串
如果有一个正整数从左、右来读都是一样的,则称为回文式数<
简称回数>
;
比如101,32123,999都是回数。
数学中有名的"
回数猜想"
之迷,至今未解决。
回数猜想:
任取一个数,再把它倒过来,并把这两个数相加,然后把这个和数再倒过来,与原和数相加,重复此过程,一定能获得一个回数。
例:
68倒过来是86
68+86=154
154+541=605
605+506=1111<
回数>
编程,输入任意整数,按上述方法产生一个回数,为简便起见,最多计算7步,看是否能得到一个回数。
主函数中接收键盘数据,必须用scanf<
"
%ld"
&
变量名>
接收整型变量,
显示该数与其倒数的和,输出每一步计算步骤。
子函数1,计算该数的倒数。
子函数2,验证和是否为回数,
是则主函数打印"
经过n次计算,得到回数"
超过7次未能得到回数,显示,"
经过n次计算,未得到回数"
求Sn=a+aa+aaa+------+aaaaaaa<
n个a>
其中a和n都从键盘中输入,如从键盘中输入2,5,则计算S5=2+22+222+2222+22222。
#include"
stdio.h"
voidmain<
>
{
inta,n,i=1;
longs=0,t=0;
printf<
a="
;
scanf<
%d"
a>
printf<
n="
scanf<
n>
while<
i<
=n>
{
t=t+a;
s=s+t;
a=a*10;
++i;
}
sum=%d"
s>
}
两个乒乓球队进行比赛,各出三人。
甲队为A,B,C三人,乙队为X,Y,Z三人。
已抽签决定比赛名单,有人向队员打听比赛的名单,A说他不和X比,C说他不和X、Z比,编程找出三对选手的对手名单。
注:
使用穷举法
#include"
intmain<
{inti,j,k;
for<
i=1;
=3;
++i>
{for<
j=1;
j<
++j>
{for<
k=1;
k<
++k>
{if<
i==j||j==k||i==k>
continue;
if<
i!
=1&
&
k!
=3>
{printf<
Avs%c\n"
i+'
X'
-1>
Bvs%c\n"
j+'
printf<
Cvs%c\n"
k+'
return0;
}
}
}
return0;
}
编写一个函数,函数说明为:
charlastchar<
charstr[]>
功能:
求一个字符串的最后一个字符,如果是空串,则返回空字符。
再利用该函数编程,输入两个字符串,输出第一字符串的最后一个字符和第二个字符串的最后一个字符。
韩信点兵。
韩信有一队兵,他想知道有多少人,便让士兵排队报数:
按从1至5报数,最末一个士兵报的数为1;
按从1至6报数,最末一个士兵报的数为5;
按从1至7报数,最末一个士兵报的数为4;
最后再按从1至11报数,最末一个士兵报的数为10。
编程求韩信至少有多少兵?
{inti;
for<
i++>
{if<
i%5==1&
i%6==5&
i%7==4&
i%11==10>
{printf<
i>
break;
}}}
用递归方法计算下列函数的值:
fx<
x,n>
=x-x2+x3-x4+......<
n-1xnn>
写出递归函数的原型
编写程序
4用递归法将一个整数转换成字符形式输出。
例如输入483,应输出字符串"
483"
其程序如下,请验证,并修改程序,增加显示出输入数字的位数的功能,并使输出结果与下图一致。
voidconvert<
longn>
{longi;
if<
<
i=n/10>
!
=0>
convert<
i>
putchar<
n%10+'
0'
main<
{longnumber;
number>
number<
0>
{putchar<
'
-'
number=-number;
convert<
利用以下公式,编程计算π的值,直到最后一项的绝对值<
用函数fabs<
>
小于0.0001为止。
[程序1]
题目:
有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?
都是多少?
1.程序分析:
可填在百位、十位、个位的数字都是1、2、3、4。
组成所有的排列后再去
掉不满足条件的排列。
2.程序源代码:
conio.h"
main<
inti,j,k;
\n"
5;
/*以下为三重循环*/
j++>
for<
k++>
if<
=k&
=j&
j!
=k>
/*确保i、j、k三位互不相同*/
%d,%d,%d\n"
i,j,k>
getch<
===========================================
[程序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,求应发放奖金总数?
请利用数轴来分界,定位。
注意定义时需把奖金定义成长整型。
longinti;
intbonus1,bonus2,bonus4,bonus6,bonus10,bonus;
bonus1=100000*0.1;
bonus2=bonus1+100000*0.75;
bonus4=bonus2+200000*0.5;
bonus6=bonus4+200000*0.3;
bonus10=bonus6+400000*0.15;
if<
=100000>
bonus=i*0.1;
elseif<
=200000>
bonus=bonus1+<
i-100000>
*0.075;
=400000>
bonus=bonus2+<
i-200000>
*0.05;
=600000>
bonus=bonus4+<
i-400000>
*0.03;
=1000000>
bonus=bonus6+<
i-600000>
*0.015;
else
bonus=bonus10+<
i-1000000>
*0.01;
bonus=%d"
bonus>
[程序3]
一个整数,它加上100后是一个完全平方数,再加上168又是一个完全平方数,请问该数是多少?
在10万以内判断,先将该数加上100后再开方,再将该数加上268后再开方,如果开方后
的结果满足如下条件,即是结果。
请看具体分析:
longinti,x,y,z;
100000;
x=sqrt<
i+100>
/*x为加上100后开方后的结果*/
y=sqrt<
i+268>
/*y为再加上168后开方后的结果*/
x*x==i+100&
y*y==i+268>
/*如果一个数的平方根的平方等于该数,这说明此数是完全平方数*/
\n%ld\n"
[程序4]
输入某年某月某日,判断这一天是这一年的第几天?
以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊
情况,闰年且输入月份大于3时需考虑多加一天。
intday,month,year,sum,leap;
\npleaseinputyear,month,day\n"
%d,%d,%d"
year,&
month,&
day>
switch<
month>
/*先计算某月以前月份的总天数*/
case1:
sum=0;
case2:
sum=31;
case3:
sum=59;
case4:
sum=90;
case5:
sum=120;
case6:
sum=151;
case7:
sum=181;
case8:
sum=212;
case9:
sum=243;
case10:
sum=273;
case11:
sum=304;
case12:
sum=334;
default:
dataerror"
sum=sum+day;
/*再加上某天的天数*/
year%400==0||<
year%4==0&
year%100!
/*判断是不是闰年*/
leap=1;
leap=0;
leap==1&
/*如果是闰年且月份大于2,总天数应该加一天*/
sum++;
Itisthe%dthday."
sum>
===========================================[程序5]
输入三个整数x,y,z,请把这三个数由小到大输出。
我们想办法把最小的数放到x上,先将x与y进行比较,如果x>
y则将x与y的值进行交换,
然后再用x与z进行比较,如果x>
z则将x与z的值进行交换,这样能使x最小。
intx,y,z,t;
%d%d%d"
x,&
y,&
z>
x>
y>
{t=x;
x=y;
y=t;
}/*交换x,y的值*/
{t=z;
z=x;
x=t;
}/*交换x,z的值*/
{t=y;
y=z;
z=t;
}/*交换z,y的值*/
smalltobig:
%d%d%d\n"
x,y,z>
===========================================[程序6]
用*号输出字母C的图案。
可先用'
*'
号在纸上写出字母C,再分行输出。
HelloC-world!
****\n"
*\n"
*\n"
===========================================[程序7]
输出特殊图案,请在c环境中运行,看一看,VeryBeautiful!
字符共有256个。
不同字符,图形不一样。
chara=176,b=219;
%c%c%c%c%c\n"
b,a,a,a,b>
a,b,a,b,a>
a,a,b,a,a>
==============================================================
[程序8]
输出9*9口诀。
分行与列考虑,共9行9列,i控制行,j控制列。
inti,j,result;
10;
result=i*j;
%d*%d=%-3d"
i,j,result>
/*-3d表示左对齐,占3位*/
/*每一行后换行*/
[程序9]
要求输出国际象棋棋盘。
用i控制行,j来控制列,根据i+j的和的变化来控制输出黑方格,还是白方格。
inti,j;
i=0;
8;
j=0;
i+j>
%2==0>
%c%c"
219,219>
==============================================================
[程序10]
打印楼梯,同时在楼梯上方打印两个笑脸。
用i控制行,j来控制列,j根据i的变化来控制输出黑方格的个数。
\1\1\n"
/*输出两个笑脸*/
11;
=i;
.:
.:
经典c程序100例==11--20:
.
经典c程序100例==11--20
[程序11]
古典问题:
有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月
后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?
兔子的规律为数列1,1,2,3,5,8,13,21....
longf1,f2;
inti;
f1=f2=1;
=20;
%12ld%12ld"
f1,f2>
i%2==0>
/*控制输出,每行四个*/
f1=f1+f2;
/*前两个月加起来赋值给第三个月*/
f2=f1+f2;
[程序12]
判断101-200之间有多少个素数,并输出所有素数。
判断素数的方法:
用一个数分别去除2到sqrt<
这个数>
如果能被整除,
则表明此数不是素数,反之是素数。
intm,i,k,h=0,leap=1;
m=101;
m<
=200;
m++>
k=sqrt<
m+1>
i=2;
=k;
m%i==0>
leap>
%-4d"
m>
h++;
h%10==0>
\nThetotalis%d"
h>
[程序13]
打印出所有的"
水仙花数"
所谓"
是指一个三位数,其各位数字立方和等于该数
本身。
例如:
153是一个"
因为153=1的三次方+5的三次方+3的三次方。
利用for循环控制100-999个数,每个数分解出个位,十位,百位。
inti,j,k,n;
waterflower'
numberis:
n=100;
n<
1000;
n++>
i=n/100;
/*分解出百位*/
j=n/10%10;
/*分解出十位*/
k=n%10;
/*分解出个位*/
i*100+j*10+k==i*i*i+j*j*j+k*k*k>
%-5d"
n>
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言 编程 练习 试题 绝对 经典