C语言试题 四

C语言试题 四
C语言试题 四

C语言试题四

6.9 巧分橘子

一家农户以果园为生,一天,父亲拿出一堆橘子,共2520个,准备分给他的6个儿子。

父亲按事先写在一张纸上的数字把这堆橘子分完,每个人分到的橘子的个数都不相同。

然后他说:“老大,把你分到的橘子分1/8给老二,老二拿到后,连同原来的橘子分1/7给老三,老三拿到后,

连同原来的橘子分1/6给老四,以此类推,最后老六拿到后,连同原来的橘子分1/3给老大,这样,

你们每个人分到的橘子就一样多了。”问兄弟6人原先各分到多少只橘子。请将兄弟6人的橘子数存储到一维数组中,

并按照下列各式输出(下面只提供格式,数据不准确):

x[1]=111

x[2]=222

x[3]=333

x[4]=444

x[5]=555

x[6]=666

#include<stdio.h>

void main()

{

int a[6],b[6],i;

for(i=0;i<6;i++)

{

a[i]=2520/6;

b[i]=8-i;

}

a[0]=a[0]-(a[5]/(b[5]-1));

for(i=5;i>=1;i--)

{

a[i]=a[i]+(a[i]/(b[i]-1))-(a[i-1]/(b[i-1]-1));

}

a[0]=a[0]*b[0]/(b[0]-1);

for(i=0;i<6;i++)

printf("x[%d]=%d\n",i+1,a[i]);

}

选做题6.1 大家一起做游戏

幼儿园的小朋友们刚学习了如何数数,阿姨在下课时组织大家一起玩游戏。规则如下:所有的小朋友绕成一圈,顺序排号,

从第一个小朋友开始报数,

凡是报到固定数字(例如5)的,都退出该游戏,

直到只剩下一位小朋友游戏才中止。

每个小朋友都希望自己能有更多的练习数数的机会,所以都希望成为最终被留下的那位。

现在,请大家帮小朋友们计算一下,在第一次排号的时候排到第几位才能成为最终被留下的小朋友。

输入:小朋友的个数(<=50),要被练习的数字

输出:最终被留下的小朋友的序号

说明:如“要被练习的数字”是5,则每次数到5的同学要退出该游戏

#include<stdio.h>

void main()

{

int N,n,i,s=0,a;

scanf("%d%d",&N,&n);

for(i=2;i<=N;i++)

s=(s+n)%i;

a=s+1;

printf("The left child is NO %d.\n",a);

}

选做题6.2 猜数字

有如下一组数字,其中每个数字都在 1 ~ 63 之间,

1 3 5 7 9 11 13 15 17 19 21 23 25 27 29 31 33 35 37 39 41 43 45 47 49 51 53 55 57 59 61 63

2 3 6 7 10 11 14 15 18 19 22 23 26 27 30 31 34 35 38 39 42 43 46 47 50 51 54 55 58 59 62 63

4 5 6 7 12 13 14 15 20 21 22 23 28 29 30 31 36 37 38 39 44 45 46 47 52 53 54 55 60 61 62 63

8 9 10 11 12 13 14 15 24 25 26 27 28 29 30 31 40 41 42 43 44 45 46 47 56 57 58 59 60 61 62 63

16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63

32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63

现在需要编写一个程序,当从键盘输入某数字在且仅在哪几行出现了,该程序可以“猜”出这个数字是几。

输入:程序的输入是一串以空白

符分开的数字,当输入0 时表示输入结束。

输出:输出猜到的数字。

#include<stdio.h>

#include<math.h>

void main()

{

int i,sum=0;

do

{

scanf("%d",&i);

sum=sum+pow(2,i-1);

}while(i!=0);

printf("%d\n",sum);

}

选做题6.3 小蜜蜂

一只小蜜蜂在如下图所示的蜂窝上爬行。它爬行时,只能从一个格爬到相邻的大号格子中。例如,

从1 号格子可以爬到 2 号或者3 号格子,

从2 号则可以爬到 3 号或者 4 号格子。

请问从一个格子a 爬到一个格子 b 一共有多少种可行的路线。

输入:分别是起始点 a 和终止点 b 的编号。( a 和 b 在1~100 之间,且a<b 。)

输出:可行的路线数目

#include<stdio.h>

void main()

{

int a,b,x,i;

int f[100];

f[1]=1;f[2]=2;

scanf("%d%d",&a,&b);

x=b-a;

if(x==1)

printf("%d\n",f[1]);

if(x==2)

printf("%d\n",f[2]);

if(x>=3)

{

for(i=3;i<=x;i++)

f[i]=f[i-1]+f[i-2];

printf("%d\n",f[x]);

}

}

选做题6.4 数制转换

我们通常使用的都是十进制的数字,但其实在生活中也经常会使用其它进制。这个题目会给你两个不同的数字,它们不属于同一进制,要求你计算出当它们分别处于何种进制之中时,两个数字相等。

譬如12 和 5 ,在十进制下它们是不等的,但若12 使用 3 进制而 5 使用六进制或十进制时,它们的值就是相等的。

因此只要选择合适的进制,12 和 5 就可以是相等的。

程序的输入是两个数字M 和N( 其十进制的值不超过1000000000) ,它们的进制在2~36 之间。对于十以下的数字,

用0~9 表示,而十以上的数字,则使用大写的A~Z 表示。

求出分别在2~36 哪种进制下M 和N 相等。若相等则输出相应的进制,若不等则输出错误信息。信息的格式见测试用例。

#define N 50

#include"string.h"

#include"stdio.h"

int main()

{

char a[N],b[N],d[N],e[N],d0[N];

int i,j,o,r,g,h,w,t,l,k,max1,max2;

double p[N],q[N]={0},u[N],v[N]={0},c[N],f[N],m,n;

for(i=0;i<N;i++)

{

scanf("%c",&a[i]);

if(a[i]=='\x20')

{

l=i; break;

}

}

gets(d);

if(d[0]!='\x20')

{k=strlen(d);

goto C;}

if(d[0]=='\x20')

{

strcpy(d0,d);

g=strlen(d0);

for(i=0;d0[i]=='\x20';i++);

j=i;

for(i=0;i<g-j;i++)

d[i]=d0[i+j];

k=g-j;

}

C:for(i=0;i<l;i++)

{

b[i]=a[l-i-1];

if(b[i]<='\x39'&&b[i]>='\x30')

c[i]=b[i]-'0';

if(b[i]<='\x5A'&&b[i]>='\x41')

c[i]=b[i]-'7'; }

for(i=0;i<k;i++)

{e[i]=d[k-i-1];

if(e[i]<='\x39'&&e[i]>='\x30') f[i]=e[i]-'0';

if(e[i]<='\x5A'&&e[i]>='\x41') f[i]=e[i]-'7'; }

max1=c[0];

for(i=1;i<l;i++)

{

if(max1<c[i]) max1=c[i];

}

if(max1==0) max1=1;

max2=f[0];

for(i=1;i<k;i++)

{

if(max2<f[i]) max2=f[i];

}

if(max2==0) max2=1;

for(i=max1+1;i<=36;i++)

{

for(j=0;j<l;j++)

{

m=c[j];

for(g=0;g<j;g++)

{

m=m*i;

}

q[i]=q[i]+m;

}

}

for(i=max2+1;i<=36;i++)

{

for(j=0;j<k;j++)

{

n=f[j];

for(g=0;g<j;g++)

{

n=n*i;

}

v[i]=v[i]+n;

}

}

for(g=max1+1;g<=36;g++)

for(h=max2+1;h<=36;h++)

{

if(q[g]==v[h])

{

w=g,t=h;

goto out;

}

}

for(i=0;i<l;i++)

printf("%c",a[i]);

printf(" is not equal to ");

for(i=0;i<k;i++)

printf("%c",d[i]);

printf(" in any base 2..36\n");

goto outs;

out:for(i=0;i<l;i++)

printf("%c",a[i]);

printf(" (base %d) = ",w);

for(i=0;i<k;i++)

printf("%c",d[i]);

printf(" (base %d)\n",t);

outs:;

}

选做题6.5 等值数列段

如果一个数列中的某一段(至少有两个元素)的各元素值均相同,则称之为等值数列段。

等值数列段中元素的个数叫做等值数列段的长度。

输入:由N个元素组成的整数数列A(其中N<=50)

输出:A中长度最大的等值数列段的始末位置,如果没有等值数列段,则输出No equal number list.

说明:始末位置是指数组下标,即0表示第一个元素。

如果有多个同等长度的等值数列,只输出第一个等值数列的起始位置。

当在一个LIST中出现两个等长的连续串的时候,我们的答案应该是第一个等长串。

#include<stdio.h>

void main()

{

int a[50];

int f[10]={0};

int n,i,j,k=-1,t,q,s,o,o1,count=1,max=-1;

scanf("%d",&n);

for(i=0;i<=n-1;i++)

scanf("%d",&a[i]);

do{

for(j=0;j<=n-1;j++)

{

if(a[j]==a[j+1])

{

count=count+1;

k=count;

f[j+1]=f[j+1]+k;

}

if(a[j]!=a[j+1])

{

count=1;

continue;

}

max=k;

}

}while(max<k);

if(max==-1)

printf("No equal number list.\n");

//for(q=0;q<=n-1;q++)

//printf("%d ",f[q]);

//printf("\n");

else{

o=f[0];

for(s=1;s<=n-1;s++)

{

if(f[s]>o)

{

o=f[s];

o1=s;

}

}

//printf("%d %d",o1,o);

//printf("\n");

printf("The longest equal number list is from %d to %d.\n",o1-o+1,o1); }

}

选做6.6 邮票组合

背景:我们寄信都要贴邮票,在邮局有一些小面值的邮票,通过这些小面值邮票中的一张或几张的组合,

可以满足不同邮件的不同的邮资。

现在,邮局有4种不同面值的邮票。在每个信封上最多能贴5张邮票,面值可相同,可不同。

输入:四种邮票的面值。

输出:用这四种面值组成的邮资最大的从1开始的一个连续的区间。

说明:如结果为10,则表明使用4张邮票可组合出1、2、3、4、5、6、7、8、9、10这些邮资。

名词解释:

资:就是你寄东西需要花多少钱。

邮票面额:是由国家发行的具有固定价格的花纸片,被称为邮票。

如果你寄东西,邮局称了重量,告诉你要240分。这样你就要贴邮票了。

如果现在邮局的邮票有面值为80分、50分、20分和10分的四种,你就可以采用不同的组合得到240的邮资,

例如:采用3张80分的可以凑出240分;或者24张10分的凑起来240分也可以。显然不同邮票的组合都可以得到同样一种邮资。

#include<stdio.h>

int neng(int a[],int max)

{

int i,j,k,m,n;

int sum;

for(i=0;i<5;i++)

for(j=0;j<5;j++)

for(k=0;k<5;k++)

for(m=0;m<5;m++)

for(n=0;n<5;n++)

{

sum=a[i]+a[j]+a[k]+a[m]+a[n];

if (sum==max)

return 1;

}

return 0;

}

void main()

{

int a[5],i;

int max=0;

a[4]=0;

scanf("%d%d%d%d",&a[0],&a[1],&a[2],&a[3]); while(1)

{

if(neng(a,max))

{

max++;

}

else break;

}

printf("The max is %d.\n",max-1);

}

选做6.7 十进制数转换为16位二进制数

将任一正整数(<65536)转换为16 位二进制形式。

输入:正整数

输出:正整数的16 位二进制数

友情提示:定义一个整型数组,数组有16个元素,保存变换后的二进制数。

#include<stdio.h>

void main()

{

int n,i;

int a[16];

scanf("%d",&n);

if(n>0&&n<65536)

{

for(i=0;i<=15;i++)

{

a[i]=n%2;

n=n/2;

}

for(i=15;i>=0;i--)

printf("%d",a[i]);

printf("\n");

}

else

printf("Invalid input!\n");

}

选做题6.9 折半插入排序

排序是程序设计中的重要内容之一,据不完全统计,在一般的数据处理程序中,排序占去了处理机时间的四分之一,而在典型的安装程序中,一半以上的时间用在对表的排序上。

常用的排序算法有:直接插入排序,折半插入排序,希尔排序,起泡排序,快速排序,选择排序,堆排序等。其中直接插入排序的基本操作是将一个记录插入到已排好序的有序表中,从而得到一个新的、记录数增1的有序表。在直接插入排序中,为了找到插入位置,采用了顺序查找的方法。为了提高查找速度,可以采用折半查找,这种排序称折半插入排序。

折半查找法先取有序数组的中间元素与查找值相比较。如相等则查找成功;如查找值大于中间元素,则再取高半部的中间元素与查找值相比较。如查找值小于中间元素,则再取低半部的中间元素与查找值相比较。如此重复直到查找成功或最终未找到该数为止。在折半插入排序算法中,由于进行关键字比较的次数比较少,所以算法的效率就比较高。

例如:有序列10,90,80,30,20,15。我们进行折半插入排序的过程如下:

初始(第1趟):有序子序列为空。待排序数

据为10,则不需要进行关键字比较,直接插入。

第2趟:有序子序列为“10”,待排序数据为90,进行1次比较就可以确定插入位置,得到长度+1的有序子序列“10,90”。此时比较次数为 1 。

第2趟:有序子序列为“10,90”。待排序数据为80,取有序序列中间(取整)的元素10进行第 1 次比较,80大;则应该从“90”这个子序列中进行折半插入80,进行第2 次比较,定位应该的插入位置,得到有序序列“10,80,90”。此趟比较次数为2。

第3趟:有序子序列为“10,80,90”。待排序数据为30,取有序序列中间的元素80进行第1 次比较,30小;则应该从“10”这个子序列中进行折半插入30,进行第 2 次比较,可以定位应该插入的位置,得到新的长度+1的有序子序列。此趟比较次数为2。

第4趟:有序子序列为“10,30,80,90”。待排序数据为20,取有序序列中间的元素30进行第 1 次比较,20小;则应该从“10”这个子序列中进行折半插入20,进行第2 次比较,可以确定应该插入的位置。此趟比较次数为2。

第5趟:有序子序列为“10,20,30,80,90”。待排序数据为15,取有序序列中间的元素30进行第1 次比较,15小;则应该从“10,20”这个子序列中进行折半插入15,取子序列中间的元素10,进行第 2 次比较,15大,则应该从“20”这个子序列中进行折半插入排序,再进行 1 次比较就可以确定应该插入的位置。此趟比较次数为3。

此时,完成排序,得到升序序列“10,15,20,30,80,90”。在整个排序过程中进行关键字比较的总次数= 0+1+2+2+2+3 = 10。

输入:数列中元素个数(元素数量<=100)

数列

输出:使用折半插入排序后的有序升序数列

在折半插入排序过程中进行关键字比较的次数

说明:输出个数列之间用空格分隔

#include <stdio.h>

int main(){

int n,a[100],b[100],i,j,count=0,lengthb=1;

scanf("%d\n",&n);

for(i=0;i<n;i++)

scanf("%d",&a[i]);

b[0]=a[0];

for(i=1;i<n;i++){

int c=0,d=lengthb-1,flag=0;

do {

if(a[i]>b[(c+d)/2]){ //待插入数字大于中间值

c=(c+d)/2+1;

count++;

}

else {

if(a[i]<b[(c+d)/2]){ //待插入数字小于中间值

d=(c+d)/2-1;

count++;

}

else {

count++;

flag=1;

break;

}

}

}

while(c<=d);

//处理最后一个数字

if(flag==0){

for(j=i-1;j>=c;j--){

b[j+1]=b[j];

}

b[c]=a[i];

lengthb++;

}

}

for(i=0;i<lengthb;i++){

printf("%d",b[i]);

if(i!=lengthb-1)printf(" ");

}

printf("\n%d\n",count);

return 0;

}

8.1 合并字符串

输入两个已经按从小到大顺序排列好的字符串,编写一个合并两个字符串的函数,使合并后的字符串,仍然是从小到大排列。

输入:两个已经排好顺序(升序)的两个字符串

输出:一个合并在一起的有序(升序)的字符串

要求:设计一个效率尽量高的算法,对每个字符串只扫描一遍就可以了。

如果采用先进行串连接,然后再进行排序的算法,则效率太低了。

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

int main()

{

char a[100],b[100],t;

int k,i,j;

gets(a);

gets(b);

strcat(a,b);

k=strlen(a);

for(j=1;j<=k;j++)

for(i=0;i<k-j;i++)

if(a[i]>=a[i+1])

{

t=a[i];

a[i]=a[i+1];

a[i+1]=t;

}

puts(a);

return 0;

}

8.3 删除重复字符

背景:

输入一个长度不超过100 的字符串,删除串中的重复字符。

输入:

输入要检查的字符串,长度不超过100个字符。例如:abacaeedabcdcd。输出:

删除重复字符后的字符串。例如:abced。

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

int main()

{

char a[100],b[100];

int n,i,j,cnt=1;

gets(a);

n=strlen(a);

b[0]=a[0];

for(i=1;i<n;i++)

{

for(j=0;j<i;j++)

{

if(a[i]==a[j])

break;

}

if(a[i]==a[j]&&i==j)

{

b[cnt]=a[i];

cnt++;

}

}

for(i=0;i<cnt;i++)

printf("%c",b[i]);

printf("\n");

return 0;

}

8.4 删除字符串中指定字符

输入两个字符串s1 和s2 ,在s1 中删除任何s2 中有的字符。例如,s1 :“abc123ad ”,s2 :“a1 ”,则输出“bc23d ”。

输入:两个字符串s1 和s2

输出:删除后的字符串s1

#include <stdio.h>

#include <stdlib.h>

#include <string.h>

int main()

{

char a[100],b[100],c[100];

int x,y,i,j,cnt;

scanf("%s",a);

scanf("%s",b);

x=strlen(b);

y=strlen(a);

for(j=0;j<x;j++)

{

cnt=0;

for(i=0;i<y;i++)

if(a[i]!=b[j])

{

c[cnt]=a[i];

cnt++;

}

strcpy(a,c);

y=cnt;

}

for(i=0;i<cnt;i++)

printf("%c",c[i]);

printf("\n");

return 0;

}

8.5 单词有多少

用空格或换行分开的字符串称为单词。输入多行字符串,直到遇到了单词"stop" 时才停止。最后输出单词的数量。用于分割单词的空格或换行可能多于1个。

输入:多个字符串

输出:单

词的数量

#include <stdio.h>

#include <malloc.h>

#include <string.h>

void main()

{

int count=0;

char *word ;

while(1)

{

word=(char *) malloc (sizeof(char)*20);

scanf("%s",word);

++count;

if(0==strcmp(word,"stop"))

break;

free(word);

}

printf("%d\n",count-1);

}

8.6 在指定位置插入字符串

输入两个字符串s1 、s2 和s1 中任意字符k ,在s1 中的指定字符k 第一次出现的位置处插入字符串s2 并输出。

输入:两个字符串s1 、s2 和s1 中任意字符k

输出:插入后的字符串s1

#include<stdio.h>

#include<string.h>

void main()

{

char s1[100],s2[100],s3[100];

char c;

int i,j,n,t,count=-1;

gets(s1);

gets(s2);

n=strlen(s1);

t=strlen(s2);

scanf("%c",&c);

for(i=0;i<=n-1;i++)

{count=count+1;

if(c==s1[i])

break;}

for(i=0;i<count;i++)

s3[i]=s1[i];

for(i=count;i<count+t;i++)

s3[i]=s2[i-count];

for(i=count+t;i<=n+t;i++)

s3[i]=s1[i-t];

puts(s3);

/*for(i=0;i<q;i++)

{

printf("%c",s3[i]);

}

printf("\n");*/

}

选做T 8.1 拱猪计分

背景:拱猪是一种很有趣的扑克牌游戏。即使你不知道它的玩法,你也可以由它的计分方式来了解它的趣味性。假设在此我们仅考虑四个人的拱猪牌局,本题要求你根据下面的计分规则,在牌局结束时计算四位玩家所得分数。

我们分别以S、H、D及C来代表黑桃,红心,方块及梅花,并以数字1至13来代表A、2、…、Q、K等牌点,例如:H1为红心A,S13为黑桃K。

牌局结束时,由各玩家持有的有关计分的牌(计分牌)仅有S12(猪),所有红心牌,D11(羊)及C10(加倍)等16张牌。其它牌均弃置不计。若未持有这16张牌之任一张则以得零分计算。

若持有C10的玩家只有该张牌而没有任何其它牌则得+50分,若除了C10 还有其它计分牌,则将其它计分牌所得分数加倍计算。

若红心牌不在同一家,则H1至H13等13张牌均以负分计,其数值为-50,-2,-3,-4,-5,-6,-7,-8,-9,-10,-20,-30,-40。而且S12与D11分别以-100及+100分计算。

若红心牌H1至H13均在同一家,有下列情形:

所有红心牌以+200分计算。

若S12、D11皆在吃下所有红心牌之一家,则此玩家得+500分。

而C10还是以前面所述原则计算之。

例一:若各玩家持有计分牌如下:( 每行代表一玩家所持有之牌)

S12 H3 H5 H13

D11 H8 H9

C10 H1 H2 H4 H6 H7

H10 H11 H12

则各家之得分依序为:-148 、+83 、-138 及-60 。

例二:若各玩家持有计分牌如下:(第四家未持有任何计分牌)

H1 H2 H3 H4 H5 H6 H7 H8 H9 H10 H11 H12 H13

S12 C10

D11

则各家之得分依序为:+200 、-200 、+100 及0 。

例三:若有一玩家持有所有16 张计分牌,则得+1000

分。其余三家均得零分。

输入:每个输入文件由多组测试数据构成,每组测试数据有四行,每一行第一个数为该玩家所持有计分牌总数,而后列出其所持有之所有计分牌,牌数与各计分牌均以一个以上的空格分开。相邻两组测试数据之间不会有空白行,读到四家持牌数都为0 表示文件结束。

输出:每一行输出一组测试数据对应的结果,依次输出各家所得分数,共四个整数( 含正负号,0 除外),相邻两个整数之间以一个空格分开,符号和数字间不可以有空格。每组输出间不需要有空白行。

#include "stdio.h"

int myinput(int card[],int number[])

{

int i,n;

char s[5];

for(i=0;i<4;i++)

{

scanf("%d",&n);

number[i]=n;

while(n--)

{

scanf("%s",s);

switch(s[0])

{

case 'S':card[13]=i;break;

case 'D':card[14]=i;break;

case 'C':card[15]=i;break;

case

'H':s[2]=='\0'?(card[s[1]-'1']=i):(card[s[2]-'1&# 39;+10]=i);

}

}

}

return number[0]+number[1]+number[2]+number[3];

}

int main()

{

int

value[15]={-50,-2,-3,-4,-5,-6,-7,-8,-9,-10,-20,-30,-40,-100,100},

card[16],

score[4]={0,0,0,0},

number[4],

i,s,

input();

while(myinput(card,number))

{

for(i=0,s=0;i<13;i++)

s+=card[i];

if(s%13)

{

for(i=0;i<15;i++)

score[card[i]]+=value[i];

}

else

{

if(card[0]==card[13]&&card[13]==card[14])

score[card[0]]+=500;

else

{

score[card[0]]+=200;

score[card[14]]+=value[14];

score[card[13]]+=value[13];

}

}

score[card[15]]+=number[card[15]]==1?50:score[card[15]];

for(i=0;i<4;i++)

printf("%s%d%s",score[i]>0?"+":"",score[i],i= =3?"\n":" ");

for(i=0;i<4;i++)

score[i]=0;

}

return 0;

}

选作T 8.2 合并果子

在一个果园里,多多已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆。多多决定把所有的果子合成一堆。

每一次合并,多多可以把两堆果子合并到一起,消耗的体力等于两堆果子的重量之和。可以看出,所有的果子经过n-1次合并之后,就只剩下一堆了。多多在合并果子时总共消耗的体力等于每次合并所耗体力之和。

因为还要花大力气把这些果子搬回家,所以多多在合并果子时要尽可能地节省体力。假定每个果子重量都为1,并且已知果子的种类

数和每种果子的数目,你的任务是设计出合并的次序方案,使多多耗费的体力最少,并输出这个最小的体力耗费值。

例如有3种果子,数目依次为1,2,9。可以先将1、2堆合并,新堆数目为3,耗费体力为3。接着,将新堆与原先的第三堆合并,又得到新的堆,数目为12,耗费体力为12。所以多多总共耗费体力=3+12=15。可以证明15为最小的体力耗费值。

输入:输入包括两行,第一行是一个整数n(1<=n<=10000),表示果子的种类数。第二行包含n个整数,用空格分隔,第i个整数ai(1<=ai<=10000)是第i种果子的数目。

输出:输出包括一行,这一行只包含一个整数,也就是最小的体力耗费值。输入数据保证这个值小于231。

#include<stdio.h>

#include<string.h>

#include<math.h>

void main()

{

int i,j,k,t,n,sum=0;

int a[10]={0};

int b[10]={0};

char s[10][100];

scanf("%d",&n);

for(i=1;i<=n;i++)

scanf("%s",s[i]);

for(t=1;t<=n;t++)

a[t]=strlen(s[t]);

for(i=1;i<=n;i++)

for(j=0;j<a[i];j++)

s[i][j]=s[i][j]-48;

for(j=1;j<=n;j++)

{

for(i=0;i<=a[j]/2-1;i++)

{

t=s[j][i];

s[j][i]=s[j][a[j]-1-i];

s[j][a[j]-1-i]=t;

}

}

for(j=1;j<=n;j++)

{

for(i=0;i<=a[j];i++)

{

b[j]=b[j]+s[j][i]*pow(10,i);

}

}

for(j=1;j<=n-1;j++)

for(i=1;i<=n-j;i++)

{

if(b[i]>b[i+1])

{

t=b[i];

b[i]=b[i+1];

b[i+1]=t;

}

}

sum=(n-1)*(b[1]+b[2]);

for(i=2;i<=n-1;i++)

sum=sum+(n-i)*b[i+1];

printf("%d\n",sum);

}

选作T 8.3 安全的密码

随着电子设备的广泛运用,密码也渐渐融入每个人的生活。保护好密码,不仅关系到个人隐私,更关系到个人的财产和安全。一个安全的密码,最好由大小写字母、数字或符号组成。包含越多种类的字符,其安全性就越高。同时密码还需要有一定的长度,通常至少要由六个以上的字符组成。

并不是每个人都喜欢这样复杂的密码,很多人在设置密码的时候,喜欢使用自己的名字或者生日,但这是很大的安全隐患。

任务

小林正在设计一个网络交易系统,为了保证用户的密码安全,他需要一个程序,判断用户自己设置的密码是否安全,如果不安全,则给出提示。现在他向你求助,请你帮忙设计一个程序来解决这个问题。

应当按照以下的规则来判断密码是否安全:

如果密码长度小于 6 位,则不安全

如果组成密码的字符只有一类,则不安全

如果组成密码的字符有两类,则为中度安全

如果组成密码的字符有三类或以上,则为安全

通常,可以认为数字、大写字母、小写字母和其它符号为四类不同的字符。

输入:输入的第一行

是一个整数N,表明后面有多少组密码。随后的N 行输入包括N 个密码,每个密码的长度均小于20 个字符。

输出:针对每一个密码判断并输出它是否安全。对于不安全的密码输出"Not Safe",对于中度安全的密码输出"Medium Safe",对于安全的密码输出"Safe"

输入样例

41234abcdefABC1231#c3Gh输出样例Not SafeNot SafeMedium SafeSafe

#include<stdio.h>

#include<string.h>

void main()

{

int n,i,j,k,t,flag1=0,flag2=0,flag3=0,flag4=0; char s[20][50];

scanf("%d",&n);

for(i=0;i<=n;i++)

gets(s[i]);

for(i=1;i<=n;i++)

{

t=strle

(完整版)C语言试题及答案解析

C语言 一、选择题(第题2分,共20分) 1.一个C程序的执行是从 A 。 A) 本程序的main函数开始,到main函数结束 B) 本程序文件的第一个函数开始,到本程序文件的最后一个函数结束 C) 本程序文件的第一个函数开始,到本程序main函数结束 D) 本程序的main函数开始,到本程序文件的最后一个函数结束 2.若x、i、j、k都是int型变量,则计算下面表达式后,x的值为 C 。 x=(i=4,j=16,k=32) A) 4 B) 16 C) 32 D) 52 3.设C语言中,一个int型数据在内存中占2个字节,则unsigned int 型数据的取值范围为 C 。 A) 0~255 B) 0~32767 C) 0~65535 D) 0~2147483647 4.设有说明:char w; int x; float y; double z;则表达式w*x+z-y值的数据类型为 D 。 A) float B) char C) int D) double 5. putchar函数可以向终端输出一个 D 。 A) 整型变量表达式 B) 实型变量值 C) 字符串 D) 字符或字符型变量值 6. printf函数中用到格式符%5s,其中数字5表示输出的字符串占用5列。如果字符串长度大于5,则输出按方式 B ;如果字符串长度小于5,则输出按方式 C 。 A) 从左起输出该字符串,右补空格 B) 按原字符长从左向右全部输出 C) 右对齐输出该字符串,左补空格 D) 输出错误信息 7.判断char型变量ch是否为大写字母的正确表达式是 C 。 A) ‘A’<=ch<=‘Z’ B) (ch>=‘A’)&(ch<=‘Z’) C) (ch>=‘A’)&&(ch<=‘Z’) D) (‘A’<= ch)AND(‘Z’>= ch) 8.已知int x=10,y=20,z=30;以下语句执行后x,y,z的值是 B 。 if(x>y) z=x; x=y; y=z; A) x=10, y=20, z=30 B) x=20, y=30, z=30 C) x=20, y=30, z=10 D) x=20, y=30, z=20 9.以下程序段______C__. x=-1; do{ x=x*x; } while(!x); A)是死循环 B)循环执行二次 C)循环执行一次 D)有语法错误 10.以下正确的描述是___B____. A)continue语句的作用是结束整个循环的执行

c语言机试题

(1)/*程序修改题目要求: 下列给定程序中,fun函数的功能是:求a=xx…xx-…-xx-xx-x (此处xx…xx表示n个x,x和n的值在1至9之间)。例如:x=3,a=6,则以上表达式为: a=333333-33333-3333-333-33-3 其值是296298。x和n是fun函数的参数,表达式的值作为函数值 传回main函数。 请改正程序中的错误,使它能得出正确的结果。 注意:不要改动main函数,不得增行或删行,也不得更改程序的 结构。每处3分,共9分*/ #include #include long fun(int x,int n) { int j; /*********found*********/ long a=0,t=1; /*********found*********/ for(j=0;j<=n;j++) t=t*10+x; a=t; for(j=1;j main() { int i,count=0,a[11]={0,10,2,8,22,16,4,10,14, 20}; /******found*****/ while(__1__) { for(i=1;i<=10;i++) a[i-1]=a[i-1]/2+a[i]/2; a[10]=a[10]/2+a[0]; for(i=1;i<=10;i++) /******found*****/ if(__2__) a[i]++; for(i=1;i<10;i++) /******found*****/ if(a[i]!=a[i+1]) __3_; if(i==10) break; else { a[0]=0; count++; } } printf("count=%d number=%d\n",count,a[1]); } 答案: 1. 2. a[i]%2==1 3. break (3)/*编程题目要求: 请输入星期几的第一个字母来判断一下是星期 几, 如果第一个字母一样,则继续判断第二个字母。 注意:部分程序段已给出,请勿改动 仅在两个found中填入你编写的若干语句。本题14分*/ #include void main() { /*******found******/ 答案:char ch1,ch2; printf("请输入第一个字母:"); ch1 = getchar(); getchar(); // 吸收换行符 if(ch1 == 'S') { printf("请输入第二个字母:"); ch2 = getchar(); switch(ch2) { case 'a': printf("星期 六\n");break; case 'u': printf("星期 日\n");break; } } else if(ch1 == 'T') { printf("请输入第二个字母:"); ch2 = getchar(); switch(ch2) 1

大学C语言考试试题及答案

精选考试类文档,如果您需要使用本文档,请点击下载! 祝同学们考得一个好成绩,心想事成,万事如意! 大学C语言考试试题及答案 姓名成绩 温馨提示:同学们,经过培训学习,你一定积累了很多知识,现在请认真、仔细地完成这张试题吧。加油! 一单项选择题 1. 在C语言中,以 D 作为字符串结束标志 A)’\n’ B)’ ’ C) ’0’ D)’\0’ 2.下列数据中属于“字符串常量”的是( A )。 A.“a” B.{ABC} C.‘abc\0’ D.‘a’ 若干个字符构成字符串 在C语言中,用单引号标识字符;用双引号标识字符串

选项B,C,分别用{}和’’标识字符串 选项D,标识字符。 3、以下说法中正确的是( C )。 A、C语言程序总是从第一个定义的函数开始执行 B、在C语言程序中,要调用的函数必须在main( )函数中定义 C、C语言程序总是从main( )函数开始执行 D、C语言程序中的main( )函数必须放在程序的开始部分 4.下列关于C语言的说法错误的是( B )。 A) C程序的工作过程是编辑、编译、连接、运行 B) C语言不区分大小写。 C) C程序的三种基本结构是顺序、选择、循环 D) C程序从main函数开始执行 5.下列正确的标识符是(C )。 A.-a1 B.a[i] C.a2_i D.int t 6.下列C语言用户标识符中合法的是( B )。 A)3ax B)x C)case D)-e2 E)union 7.下列四组选项中,正确的C语言标识符是( C )。 A) %x B) a+b C) a123 D) 123 8、下列四组字符串中都可以用作C语言程序中的标识符的是( A )。 A、print _3d db8 aBc B、I\am one_half start$it 3pai C、str_1 Cpp pow while D、Pxq My->book line# His.age 9.C语言中的简单数据类型包括(D )。 A、整型、实型、逻辑型 B、整型、实型、逻辑型、字符型 C、整型、字符型、逻辑型 D、整型、实型、字符型 10.在C语言程序中,表达式5%2的结果是 C 。 A)2.5 B)2 C)1 D)3 11.如果int a=3,b=4;则条件表达式"a

C语言题库

C语言基本概念 能将高级语言编写的源程序转换成目标程序的是______。 A) 编辑程序B) 编译程序C) 解释程序D) 链接程序 您的答案为:B 参考答案为:B 以下选项中合法的用户标识符是______。 A) long B) _2Test C) 3Dmax D) A.dat 您的答案为:B 参考答案为:B 以下叙述正确的是 A) 可以把define和if定义为用户标识符 B) 可以把define定义为用户标识符,但不能把if定义为用户标识符 C) 可以把if定义为用户标识符,但不能把define定义为用户标识符 D) define和if都不能定义为用户标识符 您的答案为:D 参考答案为:B 以下叙述正确的是 A) C语言比其他语言高级 B) C语言可以不用编译就能被计算机识别执行 C) C语言以接近英语国家的自然语言和数学语言作为语言的表达形式 D) C语言出现的最晚、具有其他语言的一切优点 您的答案为:C 参考答案为:C 在一个C语言程序中 A) main函数必须出现在所有函数之前 B) main函数必须出现在所有函数之后 C) main函数可以在任何地方出现 D) main函数必须出现在固定位置 您的答案为:C 参考答案为:C 一个C语言程序是由_______组成的。 A) 一个主程序和若干子程序 B) 若干子程序 C) 函数 D) 若干过程您的答案为:C 参考答案为:C 以下叙述中正确的是() A) C语言的源程序不必通过编译就可以直接运行 B) C语言中的每条可执行语句最终都将被转换成二进制的机器指令 C) C源程序经编译形成的二进制代码可以直接运行 D) C语言中的函数不可以单独进行编译 您的答案为:B 参考答案为:B 下列关于C语言用户标识符的叙述中正确的是

c语言试题及答案

《C语言》课程综合复习资料 一、单选题 1. 在C语言中,字符型数据在存中的存储形式是 A)原码 B)补码 C)反码 D)ASCII码 2. 在C语言中,十进制数47可等价地表示为 A) 2f B) 02f C) 57 D) 057 3. 设有定义:int x=12,n=5; 则表达式 x%=(n%2) 的值为 A) 0 B) 1 C) 2 D) 3 4. 设有定义语句:char str[][20]={,"Beijing","中国石油大学"},*p=str; 则printf("%d\n",strlen(p+20)); 输出结果是 A)10 B) 6 C) 0 D) 20 5. 已定义以下函数: fun(int *p) { return *p; } 该函数的返回值是 A)不确定的值 B)形参p所指存储单元中的值 C)形参p中存放的值 D)形参p的地址值 6. C语言中,函数返回值的类型是由 A)return语句中的表达式类型决定 B)调用函数的主调函数类型决定 C)调用函数时的临时类型决定 D)定义函数时所指定的函数类型决定 7. 有以下函数定义: void fun( int n , double x ) { …… } 若以下选项中的变量都已正确定义并赋值,则对函数fun的正确调用语句是 A) fun( int y , double m ); B) k=fun( 10 , 12.5 ); C) fun( 10 , 12.5 ); D) void fun( 10 , 12.5 ); 8. 以下选项中不能正确赋值的是 A) char b[]={′H′,′e′,′l′,′l′,′o′,′!′}; B) char b[10];b="Hello!";

C语言上机试题

1:第1题m个人的成绩存放在score数组中,请编写函数fun,它的功能就是:将低于平均分的人作为函数值返回,将低于平均分的分数放在below所指定的函数中。 2:第2题请编写函数fun,它的功能就是:求出1到100之内能北7或者11整除,但不能同时北7与11整除的所有证书,并将她们放在a所指的数组中,通过n返回这些数的个数。 3:第3题请编写函数void fun(int x,int pp[],int *n),它的功能就是:求出能整除x且不就是偶 数的各整数,并按从小到大的顺序放在pp所指的数组中,这些除数的个数通过形参n返回。 4:第4题请编写一个函数void fun(char *tt,int pp[]),统计在tt字符中"a"至U "z"26各字母各自出现的次数,并依次放在pp所指的数组中。 5:第5题请编写一个函数void fun(int m,int k,int xx[]),该函数的功能就是:将大于整数m且 紧靠m的k各素数存入xx所指的数组中。 6:第6题请编写一个函数void fun(char a[],char[],int n),其功能就是:删除以各字符串中指定下标的字符。其中,a指向原字符串,删除后的字符串存放在b所指的数组中,n中存放指定的下标。 7:第7题请编写一个函数int fun(int *s,int t,int *k),用来求除数组的最大元素在数组中的下 标并存放在k所指的储存单元中。 8:第8题编写函数fun,功能就是:根据以下攻势计算s,计算结果作为函数值返回『通过形参 传入。S=1 + 1/(1+2)+1/(1+2+3)+ ??…、+1/(1+2+3+4+ ??…+n) 9:第9题编写一个函数fun,它的功能就是:根据以下公式求p的值,结果由函数值带回。M 与n为两个正整数,且要求m>n。p=m!/n!(m-n)! 10:第10题编写函数fun,它的功能就是:利用以下的简单迭代方法求方程cos(x)-x=0的一个 实根。 迭代步骤如下:(1)取x1初值为0、0;⑵x0=x1,把x1的值赋各x0; (3) x1=cos(x0),求出一个新的x1; (4) 若x0-x1的绝对值小于0、000001,则执行步骤(5),否则执行步骤(2); (5) 所求x1就就是方程cos(x)-x=0的一个实根,作为函数值返回。 程序将输出root=0、739085。 11:第11题下列程序定义了nx n的二维数组,并在主函数中自动赋值。请编写函数fun(int a[][n]),该函数的功能就是:使数组左下半三角元素中的值全部置成0。 12:第12题下列程序定义了n x n的二维数组,并在主函数中赋值。请编写函数fun,函数的 功能使求出数组周边元素的平均值并作为函数值返回给主函数中的s。 13:第13题请编写一个函数void fun(int tt[m][n],int pp[n]),tt 指向一个m行n列的二维函数组,求出二维函数组每列中最小元素,并依次放入pp所指定一维数组中。二维数组中的数已在主函数中赋予。 14:第14题请别写函数fun,函数的功能使求出二维数组周边元素之与,作为函数值返回。二 维数组中的值在主函数中赋予。 15:第15题请编写一个函数unsigned fun(unsigned w),w 使一个大于10的无符号整数,若w 使n(n>2)位的整数,则函数求出w后n-1位的数作为函数值返回。 16:第16题请编写一个函数float fun(double h),函数的功能使对变量h中的值保留2位小树, 并对第三位进行四舍五入(规定h中的值位正数)。 17:第17题请编写一个函数fun(char *s),该函数的功能使把字符串中的内容拟置。 18:第18题编写程序,实现矩阵(3行3列)的转置(即行列互换)。 19:第19题编写函数fun,该函数的功能就是:从字符中删除指定的字符,同一字母的大、小写按不同字符处理。20:第20题编写函数int fun(int lim,int aa[max]),该函数的功能就是求出小于或等于lim的所有素数并放在aa数组中,该函数返回所求的素数的个数。 21:第21题请编写函数fun,对长度位7个字符的字符串,除首尾字符外,将其余5个字符按ascii码降序排列。

c语言试题及答案

1、以下正确的说法是( B ) (A) 用户若需要调用标准库函数,调用前必须重新定义 (B) 用户可以重新定义标准库函数,若如此,该函数将失去原有含义 (C) 系统根本不允许用户重新定义标准库函数 (D) 用户若需调用标准库函数,调用前不必使用预编译命令将该函数所在文件包括到用户源文件中,系统自动去调 2、以下正确的函数声明形式是( A ) (A) double fun(int x, int y) (B) double fun(int x; int y) (C) double fun(int x, int y); (D) double fun(int x,y); 3、以下正确的函数形式是( D ) (A) double fun(int x, int y) { z=x+y; return z;} (B) fun(int x,y) { int z; return z;} (C) fun(x,y) { int x,y; double z; z=x+y; return z;} (D) double fun(int x, int y) { double z; z=x+y; return z;} 4、以下正确的说法是( A ) 在C语言中 (A) 实参和与其对应的形参各占用独立的存储单元 (B) 实参和与其对应的形参共占用一个存储单元 (C) 只有当实参和与其对应的形参同名时才共占用存储单元 (D) 形参是虚拟的,不占用存储单元 5、若调用一个函数,且此函数中没有return语句,则正确的说法是( A ) 该函数 (A) 没有返回值 (B) 返回若干个系统默认值 (C) 能返回一个用户所希望的函数值 (D) 返回一个不确定的值 6、以下不正确的说法是( B ) C语言规定 (A) 实参可以是常量、变量和表达式 (B) 形参可以是常量、变量和表达式 (C) 实参可以为任意类型 (D) 形参应与其对应的实参类型一致 7、以下正确的说法是( C ) (A) 定义函数时,形参的类型说明可以放在函数体内 (B) return后边的值不能为表达式 (C) 如果函数值的类型与返回值类型不一致,以函数值类型为准 (D) 如果形参与实参的类型不一致,以实参类型为准 8、C语言规定,简单变量做实参时,它和对应形参之间的数据传递方式是( B ) (A) 地址传递 (B) 单向值传递 (C) 由实参传给形参,再由形参传回给实参 (D) 由用户指定传递方式

2020C语言考试题库及答案

精选考试类应用文档,如果您需要使用本文档,请点击下载,另外祝您生活愉快,工作顺利,万事如意! 精选考试类文档,如果需要,请下载,希望能帮助到你们! 2020C语言考试题库及答案

姓名成绩 温馨提示:同学们,经过培训学习,你一定积累了很多知识,现在请认真、仔细地完成这张试题吧。加油! 一单项选择题 1. 在C语言中,以 D 作为字符串结束标志 A)’\n’ B)’ ’ C) ’0’ D)’\0’ 2.下列数据中属于“字符串常量”的是( A )。 A.“a” B.{ABC} C.‘abc\0’ D.‘a’ 若干个字符构成字符串 在C语言中,用单引号标识字符;用双引号标识字符串 选项B,C,分别用{}和’’标识字符串 选项D,标识字符。 3、以下说法中正确的是( C )。 A、C语言程序总是从第一个定义的函数开始执行 B、在C语言程序中,要调用的函数必须在main( )函数中定义

C、C语言程序总是从main( )函数开始执行 D、C语言程序中的main( )函数必须放在程序的开始部分 4.下列关于C语言的说法错误的是( B )。 A) C程序的工作过程是编辑、编译、连接、运行 B) C语言不区分大小写。 C) C程序的三种基本结构是顺序、选择、循环 D) C程序从main函数开始执行 5.下列正确的标识符是(C )。 A.-a1 B.a[i] C.a2_i D.int t 6.下列C语言用户标识符中合法的是( B )。 A)3ax B)x C)case D)-e2 E)union 7.下列四组选项中,正确的C语言标识符是( C )。 A) %x B) a+b C) a123 D) 123 8、下列四组字符串中都可以用作C语言程序中的标识符的是( A )。 A、print _3d db8 aBc B、I\am one_half start$it 3pai C、str_1 Cpp pow while D、Pxq My->book line# His.age 9.C语言中的简单数据类型包括(D )。 A、整型、实型、逻辑型 B、整型、实型、逻辑型、字符型 C、整型、字符型、逻辑型 D、整型、实型、字符型 10.在C语言程序中,表达式5%2的结果是 C 。

C语言试题库(完整版)

C语言试题库 一、单项选择 第一章 C语言概述 (1)一个C程序的执行是从 A、本程序的MAIN函数开始,到MAIN 函数结束。 B、本程序文件的第一个函数开始,到本程序文件的最后一个函数结束。 C、本程序的MAIN函数开始,到本程序的最后一个函数结束。 D、本程序文件的第一个函数开始,到本程序的MAIN函数结束。(2)以下叙述正确的是 A、在C程序中,MAIN函数必须位于程序的最前面。 B、 C程序的每行中只能写一条语句。 C、 C语言本身没有输入输出语句。 D、在对一个C程序进行编译的过程中,可发现注释中的拼写错误。(3) C语言规定,在一个源程序中,MAIN主函数的位置是在: A、必须在最前面。 B、必须在系统调用的库函数的后面 C、可以在任意位置。

D、必须在最后面 (4)一个C程序是由: A、一个主程序和若干子程序组成 B、函数组成 C、若干过程组成 D、若干子程序组成 (5)以下叙述不正确的是: A、一个C源程序可由一个或多个函数组成 B、一个C源程序必须包含一个MAIN函数 C、 C程序的基本组成单位是函数 D、在C程序中,注释说明只能位于一条语句的后面 第二章数据类型、运算符与表达式 (1)若x, i, j, k都是int型变量,则计算下面表达式后,x的值为x=( i=4, j=16, k=32) A、4 B、16 C、32

D、52 (2)下列四组选项中,均不是C语言键字的选项是 A、define , IF, type B、getc, char, printf C、include, scanf, case E、 if, struct, type (3)下面四个选项中,均是不合法的用户标识符的选项是A、A,P_0,do B、float,1a0, _A C、b-a, goto, int D、_123, temp, INT (4)若有代数式3ae/bc,则正确的C语言表达式是A、a/b/c*e*3 B、3*a*e/bc C、3*a*e/b*c D、a*e/c/b*3 (5)已知各变量的类型说明如下:

C语言上机练习题

上机练习题 1.输入一个不超过五位的正整数,输出其逆数。例如输入12345,输出应为54321。 2.计算1+2+3…+n的值,n是从键盘输入的自然数。 3.从终端(键盘)读入20个数据到数组中,统计其中正数的个数,并计算这些正数之和。 4.从终端(键盘)将5个整数输入到数组a中,然后将a逆序复制到数组b中,并输出b中 各元素的值。 5.要将五张100元的大钞票,换成等值的50元,20元,10元,5元一张的小钞票,每种面 值至少1张,编程输出所有可能的换法,程序应适当考虑减少重复次数。 6.求n以内(不包括n)同时能被3和7整除的所有自然数之和的平方根s,n从键盘输入。 例如若n为1000时,函数值应为:s=153.909064。 7.一辆卡车违反交通规则,撞人后逃跑。现场有三人目击事件,但都没有记住车号,只记下 车号的一些特征。甲说:牌照的前两位数字是相同的;乙说:牌照的后两位数字是相同的,但与前两位不同;丙是数学家,他说:四位的车号刚好是一个整数的平方。请根据以上线索找出车号。 8.输入1~10之间的一个数字,输出它对应的英文单词。 9.个位数为6且能被3整除但不能被5整除的三位自然数共有多少个,分别是哪些? 10.用自然语言描述程序逻辑如下,试写程序。 ①设置环境; ②定义变量i、j、s,以及用于放置结果的变量sum,并令sum初值为0; ③i=1; ④如果i≤100,则转⑤,否则转⑧; ⑤令s=0,求前i个自然数之和,并放于变量s之中; ⑥sum=sum+s; ⑦i增加1,转④; ⑧输出和sum,结束。 11.用自然语言描述的程序逻辑为: ①设置环境; ②定义变量i、flag和password,并令flag=0,i=0; ③用户回答口令,将其赋于password变量; ④口令正确?如果是,则flag=1,转⑥。否则转⑤; ⑤回答三次口令了吗?如果没有,计数器加1后(i++),转③,否则转⑥; ⑥根据flag之值输出相应信息。 12.用自然语言描述的程序逻辑如下: ①设置环境; ②定义变量digit、x、y分别表示原始数、原始数的个位数和逆数; ③输入原始正整数x; ④从x中分解出个位数字digit; ⑤合并个位digit至逆数y中; ⑥原始数x缩小10倍:x=x/10; ⑦如果x非零,则转④; ⑧输出逆数y,结束 13.输入某三角形的三个边的长度,判断出这是个什么三角形(等腰、等边、任意,或不能构 成)。 14.输入10个数,分别统计其中正数、负数、零的个数。 15.先随机产生N个三位自然数输出,然后再输出其中同时是3、5、7倍数的数。(设N为100)

c语言试题及答案 ()

第1章 C语言概述习题 1. 单项选择题 (1) C 语言是在 B 语言的基础上产生的。 A. 回车符 B. 冒号 C. 逗号 D. 分号 (2) 在 C 语言中,每个语句必须以 D 结束。 A. 回车符 B. 冒号 C. 逗号 D. 分号 (3) 标识符和关键字间,要用 C 隔开。 A. 回车符 B. 冒号 C. 空格 D. 分号 (4) 用 C 语言编写的源文件经过编译,若没有产生编译错误,则系统将( B )。 A. 生成可执行目标文件 B. 生成目标文件 C. 输出运行结果 D.自动保存源文件 (5) 下列说法中正确的是( B )。 A. 由于 C 源程序是高级语言程序,因此一定要在 TC 软件中输入 B. 由 C 源程序是字符流组成,因此可以作为文本文件在任何文本编辑的软件中输入 C. 由于C 程序是高级语言程序,因此输入后即可执行 D. 由于 C 程序是高级语言程序,因此它由命令组成 (6) 下列说法中正确的是( A )。 A. C 语言程序由主函数和 0 个或多个函数组成 B. C 语言程序由

主程序和子程序组成 C. C 语言程序由子程序组成 D. C 语言程序由过程组成 (7) 下列说法中错误的是( D )。 A. 主函数可以分为两个部分:主函数说明部分和主函数体 B. 主函数可以调用任何非主函数的其他函数 C. 任何非主函数可以调用其他任何非主函数 D. 程序可以从任何非主函数开始执行 2. 填空题 (1) C 语言只有 37 个关键字和 9 种控制语句。 (2) C 语言是一种“中级语言”,既具有高级语言的特点又具有低级语言的特点;既适合于开发系统软件又适合于编写应用程序。 (3) 每个源程序有且只有一个主函数,系统总是从该函数开始执行C语言程序。 (4) 在 C 语言程序中允许出现的字符集是 ASCII码字符集。 (5) C 语言的程序中有特殊含义的英语单词称为保留字。 (6) C 语言标识符的长度是前 8 位有效。 (7) C 语言中,标识符的定义规则是以字母或下划线为开头。 (8) C 语言程序的注释可以出现在程序中的任何地方,它总是以 /* 符号作为开始标记,以 */ 符号作为结束标记。

c语言试题及复习资料

《程序员基本功大赛》试题 (满分100分,考试时间90分钟) 学号姓名班级: 一、单项选择题(本题共25小题,每小题2分,共50分) 1. 以下正确的C语言自定义标识符是。 A. _1a B. 2 C. D. a.12 2. C语言中,字符型数据在内存中存储形式是。 A. 原码 B. 反码 C. 补码 D. 码 3. 在C语言中,形参的缺省存储类是() A. B. C. D. 4.软件测试的目的是。 A.证明软件中没有错误 B.改正软件中的错误 C.发现软件中的错误 D.优化程序结构 5. 在C语言中,字符串"\\\t\65\""的长度是。 A. 5 B.7 C. 8 D. 12 6. 设x,由键盘输入:12.45, 能正确读入数据的输入语句是。 A. ("%5f", ); B. ("%5d", ); C. ("", x); D. ("", ); 7.十进制数2403转换成十六进制数为。 A. 963 B. 369 C. 953 D. 359

8. C语言程序中,整型常量的书写形式不包括。 A. 二进制 B. 八进制 C. 十进制 D. 十六进制 9. C语言函数返回值的类型是由决定的。 语句中的表达式类型 B.调用函数的主调函数类型 C.调用函数时临时 D.定义函数时所指定的函数类型 10.操作系统负责管理计算机系统的,其中包括处理机、存储器、设备和文件。 A.程序 B.文件 C.资源 D.进程 11.数据库系统的核心是() A.编译系统 B.数据库 C.操作系统 D.数据库管理系统 12.设 1 + 2,则= 2 * * 3 - ; 的值是多少? A. 15 B. 19 C. 9 D. 5 13.设a = 11, b = 2;执行下述程序段后,变量a和b的值分别是。 { a ; }(a > b); A. 1,3 B. 1,4 C. 2,3 D. 2,4 14.在C语言中,下列错误的说法是。 A. 函数可以递归调用 B. 不允许在函数中再定义函数

C语言题库

一、判断题(每题1分) 1.函数即可以嵌套定义,又可以嵌套调用.( × ) 2.unsigned 和void 在C 中都是保留字.( √ ) 3.表达式 ++i 表示对变量i 自加1. (√ ) 4.C 语言源程序的基本结构单位是main 函数. ( × ) 5.字符常量的长度肯定为1. (√ ) 6.char a[]={'a','b','c'};char b[]={"abc"};数组a和数组b 占用的内存空间大小不一样. ( √ ) 7.若有int i=10,,j=2; 则执行完i*=j+8;后i 的值为28. (× ) 8.int i,*p=&i;是正确的C 说明。( √ ) 9.While 循环语句的循环体至少执行一次. ( × ) 10.有数组定义int a[2][2]={{1},{2,3}};则a[0][1]的值为0. ( √ ) 11. 7&3+12的值是15.( × ) 12. C 语言本身不提供输入输出语句,输入和输出操作是由函数来 实现的.( √ ) 13. 若 a=3,b=2,c=1 则关系表达式"(a>b)==c" 的值为"真". (√ ) 14. 在C 语言中,整型数据在内存中占2个字节. ( × ) 15. 对二维数组a 来说,由于a+1与*(a+1)的值相等,因此二者的含义是一样的. (× ) 16. break 语句可用于循环体内,它将退出该重循环. ( √ ) 17. 将一个字符串"abc"赋给字符串变量str 的方法是str="abc".. (× ) 18. 参加位运算的数据可以是任何类型的数。( × ) 19. C 语言规定:在一个源程序中,main 函数的位置必须在最开始. ( × ) 20. 静态外部变量只在本文件内可用. ( √ ) 21. 若有宏定义:#define S(a,b) t=a;a=b;b=t由于变量t 没定义,所以此宏定义是错误的.( × ) 22. 字符串只能存放在字符型数组中. ( √ ) 23. 若 a=3,b=2,c=1 则关系表达式"(a>b)==c" 的值为"真". (√ ) 24. 在标准C 中,"="是判断两个数是否相等. ( × ) 25. 函数调用可以出现在执行语句中,但不能出现在表达式中. (× ) 26. break 语句可用于循环体内,它将退出该重循环. ( √ ) 27. strcat(s1,s2)函数是将字符串s1复制到字符串s2中. (× ) 28. 函数若无返回值,则它一定无形参。( × )

C语言试题

C语言题 一、判断题(每题1分,共计10分) 1.在C中,调用函数时,只能把实参的值传送给形参,形参的值不能传送给实参。() 2.使用float b定义的外部变量存放在内存中的动态存储区。() 3.如果一个函数位于C程序文件的上部,在该函数体内说明语句后的复合语句中定义 了一个变量,则该变量为局部变量,只在该复合语句中有效;。() 4.int (*ptr) (),则ptr是一维数组的名字。() 5.指针在任何情况下都可进行>,<,>=,<=,==运算。() 6.形参是局部变量,函数调用完成即失去意义。() 7.C语言程序总是从main()函数开始执行,C语言程序中的main()函数必须放在程序的开 始部分。() 8.在C语言程序中,函数的定义不能嵌套,但函数的调用可以嵌套。() 9.若函数调用时用数组名作为函数参数,实参与其对应的形参共占用同一段存储空间, 在调用函数中必须说明数组的大小,但在被调函数中可以使用不定尺寸数组。() 10.局部变量不能和全局变量重名。() 二、(共计10分) 1. 以下为Windows NT 下的32 位C程序,请计算sizeof 的值 char str[] = “Hello” ; char *p = str ; int n = 10; long d=12; 请计算 sizeof (str ) =__ (0.5分) sizeof ( p ) =__ (0.5分) sizeof ( n ) =__ (0.5分) sizeof(d)=__(0.5分) 2. 请给出如下程序的结果 int a = 3; int b = a << 3; a = ____ ,(0.5分) b = ____(0.5分) 3.int i=10, j=10, k=3; k*=i+j; k 最后的值是__(1分) 4. 1.-1,2,7,28,,126请问28和126中间那个数是__(2分) 5.如有定义语句int a[]={1,8,2,8,3,8,4,8,5,8}; ,则数组a的大小是___(1分) 6.以下程序: #include void main() { int x=10,y=10; printf("%d %d\n",x--,--y); } 输出结果为:___(0.5分),___ (0.5分) 7.函数调用语句: func((exp1,exp2),(exp3,exp4,exp5));

C语言试题及答案

C语言试题及答案 Company number【1089WT-1898YT-1W8CB-9UUT-92108】

第1章C语言概述习题1. 单项选择题 (1) C 语言是在 B 语言的基础上产生的。 A. 回车符 B. 冒号 C. 逗号 D. 分号 (2) 在 C 语言中,每个语句必须以 D 结束。 A. 回车符 B. 冒号 C. 逗号 D. 分号 (3) 标识符和关键字间,要用 C 隔开。 A. 回车符 B. 冒号 C. 空格 D. 分号 (4) 用 C 语言编写的源文件经过编译,若没有产生编译错误,则系统将( B )。 A. 生成可执行目标文件 B. 生成目标文件 C. 输出运行结果 D.自动保存源文件 (5) 下列说法中正确的是( B )。 A. 由于 C 源程序是高级语言程序,因此一定要在 TC 软件中输入 B. 由 C 源程序是字符流组成,因此可以作为文本文件在任何文本编辑的软件中输入 C. 由于C 程序是高级语言程序,因此输入后即可执行 D. 由于 C 程序是高级语言程序,因此它由命令组成 (6) 下列说法中正确的是( A )。 A. C 语言程序由主函数和 0 个或多个函数组成 B. C 语言程序由主程序和子程序组成

C. C 语言程序由子程序组成 D. C 语言程序由过程组成 (7) 下列说法中错误的是( D )。 A. 主函数可以分为两个部分:主函数说明部分和主函数体 B. 主函数可以调用任何非主函数的其他函数 C. 任何非主函数可以调用其他任何非主函数 D. 程序可以从任何非主函数开始执行 2. 填空题 (1) C 语言只有 37 个关键字和 9 种控制语句。 (2) C 语言是一种“中级语言”,既具有高级语言的特点又具有低级语言 的特点;既适合于开发系统软件又适合于编写应用程序。 (3) 每个源程序有且只有一个主函数,系统总是从该函数开始执行C语言程序。 (4) 在 C 语言程序中允许出现的字符集是 ASCII码字符集。 (5) C 语言的程序中有特殊含义的英语单词称为保留字。 (6) C 语言标识符的长度是前 8 位有效。 (7) C 语言中,标识符的定义规则是以字母或下划线为开头。 (8) C 语言程序的注释可以出现在程序中的任何地方,它总是以 /* 符号作为开始标记,以 */ 符号作为结束标记。

C语言程序设计试题及答案

C语言程序设计 一、选择题(共40分,每小题2分) 1、以下叙述不正确的是() A、一个C源程序可由一个或多个函数组成 B、一个C源程序必须包含一个main函数 C、C程序的基本组成单位是函数 D、在C程序中,注释说明只能位于一条语句的后面 2、下列四个选项中,是不合法的用户标识符的选项是() A、abc B、12AC C、sun D、 A2 3、设有语句int a=4;则执行了语句a+=a- =a*a后,变量a的值是() A、-24 B、0 C、4 D、16 4、下列运算符中优先级最高的是() A、< B、+ C、&& D、== 5、在C语言中,运算对象必须是整型数的运算符是() A、% B、/ C、%和/ D、 + 6、以下关于运算符的优先顺序的描述正确的是() A、关系运算符<算术运算符<赋值运算符<逻辑与运算符 B、逻辑与运算符<关系运算符<算术运算符<赋值运算符 C、赋值运算符<逻辑与运算符<关系运算符<算术运算符 D、算术运算符<关系运算符<赋值运算符<逻辑与运算符 7、在C语言中,如果下面的变量都是int类型,则输出的结果是()

sum=pad=5;pAd=sum++,pAd++,++pAd; printf(“%d\n”,pad); A、7 B、6 C、5 D、4 8、x、y、z被定义为int型变量,若从键盘给x、y、z输入数据,正确的输入语句是() A、 INPUT x、y、z; B、scanf(“%d%d%d”,&x,&y,&z); C、 scanf(“%d%d%d”,x,y,z); D、read(“%d%d%d”,&x,&y,&z); 9、假定从键盘输入23456< 回车 >,下面程序的输出结果是:()void main ( ) { int m,n; scanf(“%2d%3d”,&m,&n); printf(“m=%d n=%d\n”,m,n); } A、m=23 n=45 B、m=234 n=56 C、m=23 n=456 D、语句有错误 10、若运行时,给变量x输入12,则以下程序的运行结果是()main( ) { int x,y; scanf(“%d”,&x);

2020年C语言题库及答案

2020年C语言题库及答案

姓名成绩 温馨提示:同学们,经过培训学习,你一定积累了很多知识,现在请认真、仔细地完成这张试题吧。加油!一单项选择题 1. 在C语言中,以 D 作为字符串结束标志 A)’\n’ B)’’ C) ’0’ D)’\0’ 2.下列数据中属于“字符串常量”的是( A )。 A.“a” B.{ABC} C.‘abc\0’ D.‘a’ 若干个字符构成字符串 在C语言中,用单引号标识字符;用双引号标识字符串 选项B,C,分别用{}和’’标识字符串 选项D,标识字符。 3、以下说法中正确的是( C )。 A、C语言程序总是从第一个定义的函数开始执行 B、在C语言程序中,要调用的函数必须在main( )函数中定义 C、C语言程序总是从main( )函数开始执行 D、C语言程序中的main( )函数必须放在程序的开始部分 4.下列关于C语言的说法错误的是( B )。 A) C程序的工作过程是编辑、编译、连接、运行 B) C语言不区分大小写。 C) C程序的三种基本结构是顺序、选择、循环 D) C程序从main函数开始执行

5.下列正确的标识符是(C )。 A.-a1 B.a[i] C.a2_i D.int t 6.下列C语言用户标识符中合法的是( B )。 A)3ax B)x C)case D)-e2 E)union 7.下列四组选项中,正确的C语言标识符是( C )。 A) %x B) a+b C) a123 D) 123 8、下列四组字符串中都可以用作C语言程序中的标识符的是( A )。 A、print _3d db8 aBc B、I\am one_half start$it 3pai C、str_1 Cpp pow while D、Pxq My->book line# His.age 9.C语言中的简单数据类型包括(D )。 A、整型、实型、逻辑型 B、整型、实型、逻辑型、字符型 C、整型、字符型、逻辑型 D、整型、实型、字符型 10.在C语言程序中,表达式5%2的结果是 C 。 A)2.5 B)2 C)1 D)3 11.如果int a=3,b=4;则条件表达式"a

相关文档
最新文档