最新C语言上机考试题库.docx
《最新C语言上机考试题库.docx》由会员分享,可在线阅读,更多相关《最新C语言上机考试题库.docx(47页珍藏版)》请在冰豆网上搜索。
![最新C语言上机考试题库.docx](https://file1.bdocx.com/fileroot1/2022-10/29/42986d97-f56a-4883-820d-0762b144b6bf/42986d97-f56a-4883-820d-0762b144b6bf1.gif)
最新C语言上机考试题库
一、程序设计共113题(共计1130分)
第1题(10.0分)题号:
390
功能:
编写函数求1~100中奇数的平方和。
结果为166650.000000。
答案:
----------------------
floats=0;
inti;
for(i=1;i<=n;i=i+2)
s=s+i*i;
return(s);
----------------------
第2题(10.0分)题号:
320
功能:
在键盘上输入一个3行3列矩阵的各个元素的值(值
为整数),然后输出主对角线元素的积,并在fun()
函数中输出。
答案:
----------------------
intsum;
inti,j;
sum=1;
for(i=0;i<3;i++)
sum=sum*a[i][i];
returnsum;
----------------------
第3题(10.0分)题号:
324
功能:
能计算从1开始到n的自然数中偶数的平方的和,n由
键盘输入,并在main()函数中输出。
(n是偶数)
答案
intsum,i;
sum=0;
for(i=2;i<=n;i=i+2)
{
sum=sum+i*i;}
return(sum);
----------------------
第4题(10.0分)题号:
345
功能:
将两个两位数的正整数a、b合并形成一个整数放在c
中。
合并的方式是:
将a数的十位和个位数依次放在
c数的千位和十位上,b数的十位和个位数依次放在
c数的个位和百位上。
例如:
当a=45,b=12。
调用该函数后,c=4251。
------------------------------------------------*/
答案:
----------------------
*c=a/10*1000+a%10*10+b/10+b%10*100;
----------------------
第5题(10.0分)题号:
366
功能:
求一组数中大于平均值的数的个数。
例如:
给定的一组数为1,3,6,9,4,23,35,67,12,88时,函
数值为3。
答案:
----------------------
inti,k=0;
floats=0,ave;
for(i=0;is+=a[i];
ave=s/n;
printf("%f",ave);
for(i=0;iif(a[i]>ave)k++;
returnk;
----------------------
第6题(10.0分)题号:
355
功能:
对长度为8个字符的字符串,将8个字符按降序排列。
例如:
原来的字符串为CEAedcab,排序后输出为edcbaECA。
答案:
----------------------
inti,j;
chart;
for(i=0;ifor(j=i+1;jif(s[i]
{t=s[i];s[i]=s[j];s[j]=t;}
----------------------
第7题(10.0分)题号:
44
功能:
求出二维数组周边元素之和,作为函数值返回。
二
维数组的值在主函数中赋予。
答案:
----------------------
ints=0;
inti,j;
for(i=0;is=s+a[i][0]+a[i][N-1];
for(j=1;js=s+a[0][j]+a[M-1][j];
returns;
----------------------
第8题(10.0分)题号:
339
功能:
判断整数x是否是同构数。
若是同构数,函数返回1;
否则返回0。
x的值由主函数从键盘读入,要求不大
于100。
说明:
所谓“同构数”是指这样的数,这个数出现在它的
平方数的右边。
例如:
输入整数5,5的平方数是25,5是25中右侧的数,所
以5是同构数。
答案:
----------------------
intk;
k=x*x;
if((k%10==x)||(k%100==x))
return1;
else
return0;
----------------------
第9题(10.0分)题号:
383
功能:
用函数实现字符串的复制,不允许用strcpy()函数。
答案:
----------------------
inti;
for(i=0;str1[i]!
='\0';i++)
str2[i]=str1[i];
str2[i]='\0';
----------------------
第10题(10.0分)题号:
310
功能:
计算并输出给定整数n的所有因子之和(不包括1与
自身)。
注意:
n的值不大于1000。
例如:
n的值为855时,应输出704。
答案:
----------------------
ints=0,i;
for(i=2;iif(n%i==0)s=s+i;
returns;
----------------------
第11题(10.0分)题号:
354
功能:
求小于lim的所有素数并放在aa数组中,该函数返回
所求出素数的个数。
答案:
----------------------
intn=0;
inti,j;
for(i=2;i<=lim;i++)
{for(j=2;j
if(i%j==0)break;
if(j==i)aa[n++]=i;
}
returnn;
----------------------
第12题(10.0分)题号:
341
功能:
删除所有值为y的元素。
数组元素中的值和y的值由
主函数通过键盘输入。
答案:
----------------------
inti,j;
for(i=0;i<*n;)
{
if(bb[i]==y)
{for(j=i;j<*n;j++)
bb[j]=bb[j+1];
*n=*n-1;
}
else
i++;
}
----------------------
第13题(10.0分)题号:
317
功能:
求出N×M整型数组的最大元素及其所在的行坐标及
列坐标(如果最大元素不唯一,选择位置在最前面
的一个)。
例如:
输入的数组为:
123
4156
12189
10112
求出的最大数为18,行坐标为2,列坐标为1。
/答案:
----------------------
intmax,i,j;
max=array[0][0];
Row=0;
Col=0;
for(i=0;i{for(j=0;jif(max{max=array[i][j];
Row=i;
Col=j;}
}
return(max);
----------------------
第14题(10.0分)题号:
392
功能:
求一批数中最大值和最小值的积。
答案:
----------------------
inti,max,min;
max=min=a[0];
for(i=1;iif(a[i]>max)max=a[i];
elseif(a[i]return(max*min);
----------------------
第15题(10.0分)题号:
501
题目:
从键盘输入一个大写字母,要求改用小写字母输出。
答案:
c=c+32;
returnc;
第16题(10.0分)题号:
502
题目:
用while语句求1~100的累计和。
答案:
inti=1,sum=0;
while(i<=n)
{
sum=sum+i;
i++;
}
returnsum;
第17题(10.0分)题号:
409
题目:
输入华氏温度求摄氏温度。
转换公式为c=5/9(f-32),
输出结果取两位小数。
-------------------------------------------------------*/
答案:
floatn;
n=(5.0/9.0)*(m-32);
returnn;
第18题(10.0分)题号:
29
功能:
对任意输入的x,用下式计算并输出y的值。
5x<10
y=0x=10
-5x>10
答案:
intm;
if(n<10)
m=5;
else
if(n==10)m=0;
elsem=-5;
returnm;
或
intm;
if(n>=10)
if(n>10)
m=-5;
elsem=0;
elsem=5;
returnm;
第19题(10.0分)题号:
382
功能:
给定n个数据,求最小值出现的位置(如果最小值
出现多次,求出第一次出现的位置即可)。
答案:
----------------------
inti,k;
k=0;
for(i=1;iif(s[i]
return(k);
----------------------
第20题(10.0分)题号:
367
功能:
找出一批正整数中的最大的偶数。
答案:
----------------------
inti,amax=-1;
for(i=0;iif(a[i]%2==0)
if(a[i]>amax)amax=a[i];
returnamax;
第21题(10.0分)题号:
384
功能:
产生20个[30,120]上的随机整数放入二维数组a[5][4]
中,求每行元素的和。
答案:
----------------------
inti,j;
for(i=0;i<5;i++)
{b[i]=0;
for(j=0;j<4;j++)
b[i]=b[i]+a[i][j];
}
第22题(10.0分)题号:
334
功能:
求给定正整数n以内的素数之积。
(n<28)
答案:
----------------------
longi,k;
longs=1;
for(i=2;i<=n;i++)
{for(k=2;k
if(i%k==0)break;
if(k==i)s=s*i;
}
returns;
----------------------
第23题(10.0分)题号:
363
功能:
求一个给定字符串中的字母的个数。
答案:
----------------------
inti,k=0;
for(i=0;s[i]!
='\0';i++)
if(s[i]>='a'&&s[i]<='z'||s[i]>='A'&&s[i]<='Z')
k++;
returnk;
----------------------
第24题(10.0分)题号:
361
功能:
编写程序,求矩阵(3行3列)与2