4、c语言编程
5、求C语言编程题
时间问题,把下面较难的先给你回答了,其他的给你说下思路:
1: 1--199 奇数和=20000=前200项的总和/2
用for 循环就可以了,先算总和,得出的结果除以2;
2:开始定义一下 a99a1001;让后用取模的 *** 求;
取出的模看能不能被6整除,
if
a%6==0;
do
printf(" ");
}else ....
3:这个就是考试你的递归算法灵活度,前一项分子分母和等于下一项的分子,前一项分子为下一项分母;
4:这是个经典考题
main()
unsigned int i,x=1;
for(i=0;i9;i++)
x=(x+1)*2;
printf("x=%d",x);
这个 *** 是简化过的,下面是麻烦点的
main()
int day,x1,x2;
scanf("%d",day);
x2=1;
while(day0)
{x1=(x2+1)*2;/*之一天的桃子数是第2天桃子数加1后的2倍*/
x2=x1;
day--;
printf("the total is %d\n",x1);
5:这个题目是"百鸡问题"的翻版
main()
int a,b,c;
for(a=1;a33;a++)
for(b=1;b50;b++)
c=100-a-b;
if((a+b+c==100)(3*a+2*b+c/2==100))
printf("a=%d,B=%d,c=%d\n",a,b,c);
/*九九乘法表*/
#include stdio.h
int main()
int i,j;
for(i=1;i10;i++)
for(j=1;j10;j++)
printf("%dX%d=%d\t",i,j,j*i);
if(i==j)
break;
printf("\n");
return 0;
int mi(double x,int y){
if(y0) return pow(1/x,y);
else return pow(x,y);
int f(int x){
int sum=0;
while(x0) {sum+=x%10;x/=10;}
return sum;
2次
1次
int chu(int m,int n){
int i;
for(i=m;i=n;i++){
if(i%3==0||i%7==0) continue;
printf("%d\n",i);
void prime(){
int i;
for(i=2;i=100;i++){
int j;
int flag = 1;
for(j=2;j*j=i;j++) if(i%j==0) {flag = 0;break;}
if(flag) printf("%d\n",i);
【程序1】
题目:有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?
1.程序分析:可填在百位、十位、个位的数字都是1、2、3、4。组成所有的排列后再去
掉不满足条件的排列。
2.程序源代码:
main()
int i,j,k;
printf(“\n“);
for(i=1;i〈5;i++)/*以下为三重循环*/
for(j=1;j〈5;j++)
for (k=1;k〈5;k++)
if (i!=ki!=jj!=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);
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(i〈=100000)
bonus=i*0.1;
else if(i〈=200000)
bonus=bonus1+(i-100000)*0.075;
else if(i〈=400000)
bonus=bonus2+(i-200000)*0.05;
else if(i〈=600000)
bonus=bonus4+(i-400000)*0.03;
else if(i〈=1000000)
bonus=bonus6+(i-600000)*0.015;
else
bonus=bonus10+(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 (i=1;i〈100000;i++)
{ x=sqrt(i+100); /*x为加上100后开方后的结果*/
y=sqrt(i+268); /*y为再加上168后开方后的结果*/
if(x*x==i+100y*y==i+268)/*如果一个数的平方根的平方等于该数,这说明此数是完全平方数*/
printf(“\n%ld\n“,i);
【程序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:sum=0;break;
case 2:sum=31;break;
case 3:sum=59;break;
case 4:sum=90;break;
case 5:sum=120;break;
case 6:sum=151;break;
case 7:sum=181;break;
case 8:sum=212;break;
case 9:sum=243;break;
case 10:sum=273;break;
case 11:sum=304;break;
case 12:sum=334;break;
default:printf(“data error“);break;
sum=sum+day; /*再加上某天的天数*/
if(year%400==0||(year%4==0year%100!=0))/*判断是不是闰年*/
leap=1;
else
leap=0;
if(leap==1month〉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)
{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(“ *** all 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 a=176,b=219;
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 (i=1;i〈10;i++)
{ for(j=1;j〈10;j++)
result=i*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(i=0;i〈8;i++)
for(j=0;j〈8;j++)
if((i+j)%2==0)
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(i=1;i〈11;i++)
for(j=1;j〈=i;j++)
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;
f1=f2=1;
for(i=1;i〈=20;i++)
{ printf(“%12ld %12ld“,f1,f2);
if(i%2==0) printf(“\n“);/*控制输出,每行四个*/
f1=f1+f2; /*前两个月加起来赋值给第三个月*/
f2=f1+f2; /*前两个月加起来赋值给第三个月*/
【程序12】
题目:判断101-200之间有多少个素数,并输出所有素数。
1.程序分析:判断素数的 *** :用一个数分别去除2到sqrt(这个数),如果能被整除,
则表明此数不是素数,反之是素数。
2.程序源代码:
#include “math.h“
main()
int m,i,k,h=0,leap=1;
printf(“\n“);
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++;brif(h%10==0)brprintf(“\n“);br }
leap=1;
printf(“\nThe total is %d“,h);
【程序13】
题目:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数
本身。例如:153是一个“水仙花数”,因为153=1的三次方+5的三次方+3的三次方。
1.程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位。
2.程序源代码:
main()
int i,j,k,n;
printf(“’water flower’number is:“);
for(n=100;n〈1000;n++)
i=n/100;/*分解出百位*/
j=n/10%10;/*分解出十位*/
k=n%10;/*分解出个位*/
if(i*100+j*10+k==i*i*i+j*j*j+k*k*k)
printf(“%-5d“,n);
printf(“\n“);
【程序14】
题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:
(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。
(2)如果n〈〉k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,
重复执行之一步。
(3)如果n不能被k整除,则用k+1作为k的值,重复执行之一步。2.程序源代码:
/* zheng int is divided yinshu*/
main()
int n,i;
printf(“\nplease input a number:\n“);
scanf(“%d“,n);
printf(“%d=“,n);
for(i=2;i〈=n;i++)
while(n!=i)
if(n%i==0)
{ printf(“%d*“,i);
n=n/i;
else
break;
printf(“%d“,n);}
【程序15】
题目:利用条件运算符的嵌套来完成此题:学习成绩〉=90分的同学用A表示,60-89分之间的用B表示,
60分以下的用C表示。
1.程序分析:(a〉b)?a:b这是条件运算符的基本例子。
2.程序源代码:
main()
int score;
char grade;
printf(“please input a score\n“);
scanf(“%d“,score);
grade=score〉=90?’A’:(score〉=60?’B’:’C’);
printf(“%d belongs to %c“,score,grade);
【程序16】
题目:输入两个正整数m和n,求其更大公约数和最小公倍数。
1.程序分析:利用辗除法。2.程序源代码:
main()
int a,b,num1,num2,temp;
printf(“please input two numbers:\n“);
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\n“,a);
printf(“gongbeishu:%d\n“,num1*num2/a);
【程序17】
题目:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。
1.程序分析:利用while语句,条件为输入的字符不为’\n’.
2.程序源代码:
#include “stdio.h“
main()
{char c;br int letters=0,space=0,digit=0,others=0;br printf(“please input some characters\n“);br while((c=getchar())!=’\n’)br {br if(c〉=’a’c〈=’z’||c〉=’A’c〈=’Z’)brletters++;br else if(c==’ ’)brspace++;br else if(c〉=’0’c〈=’9’)br digit++;br elsebr others++;br}
printf(“all in all:char=%d space=%d digit=%d others=%d\n“,letters,
space,digit,others);
【程序18】
题目:求s=a+aa+aaa+aaaa+aa...a的值,其中a是一个数字。例如2+22+222+2222+22222(此时
共有5个数相加),几个数相加有键盘控制。
1.程序分析:关键是计算出每一项的值。
2.程序源代码:
main()
int a,n,count=1;
long int sn=0,tn=0;
printf(“please input a and n\n“);
scanf(“%d,%d“,a,n);
printf(“a=%d,n=%d\n“,a,n);
while(count〈=n)
tn=tn+a;
sn=sn+tn;
a=a*10;
++count;
printf(“a+aa+...=%ld\n“,sn);
【程序19】
题目:一个数如果恰好等于它的因子之和,这个数就称为“完数”。例如6=1+2+3.编程
找出1000以内的所有完数。
1. 程序分析:请参照程序〈--上页程序14.
2.程序源代码:
main()
static int k[10];
int i,j,n,s;
for(j=2;j〈1000;j++)
n=-1;
s=j;
for(i=1;i {
if((j%i)==0)
{ n++;
s=s-i;
k[n]=i;
if(s==0)
printf(“%d is a wanshu“,j);
for(i=0;i printf(“%d,“,k);
printf(“%d\n“,k[n]);
【程序20】
题目:一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在
第10次落地时,共经过多少米?第10次反弹多高?
1.程序分析:见下面注释
2.程序源代码:
main()
float sn=100.0,hn=sn/2;
int n;
for(n=2;n〈=10;n++)
sn=sn+2*hn;/*第n次落地时共经过的米数*/
hn=hn/2; /*第n次反跳高度*/
printf(“the total of road is %f\n“,sn);
printf(“the tenth is %f meter\n“,hn);
逻辑运算和判断选取控制
1、编制程序要求输入整数a和b,若a2+b2大于100,则输出a2+b2百位以上的数字,否则输出两数字之和。
#includestdio.h
int main()
int a,b;
printf("input two number:");
scanf("%d %d",a,b);
if((a*a+b*b)=100)
printf("\n %d",(a*a+b*b)/100);
else
printf("\n %d",a+b);
getch();
2、试编程判断输入的正整数是否既是5又是7的整数倍数。若是,则输出yes;否则输出no。
#includestdio.h
int main()
int a;
printf("input a number:");
scanf("%d",a);
if(a%5==0 a%7==0)
printf("yes");
else
printf("no");
getch();
指针
1、编一程序,将字符串computer赋给一个字符数组,然后从之一个字母开始间隔的输出该串,请用指针完成。
#includestdio.h
int main()
char string[]="computer";
char *p=string;
while(*p)
printf("%c",*p);
p++;
p++;
getch();
2、输入一个字符串string,然后在string里面每个字母间加一个空格,请用指针完成。
#includestdio.h
#includeCONIO.H
#includeSTDLIB.H
#define max 100
char * copyString;
void copy(char *,char*);
void insert(char *);
int main()
char * string;
string = (char *)malloc(max*sizeof(char));
scanf("%s",string);
insert(string);
printf("%s",string);
getch();
return 0;
void copy(char * c,char * s)
while(*s!='\0')
*c=*s;
s++;
c++;
*c='\0';
void insert(char * s)
copyString = (char*)malloc(2*max*sizeof(char));
copy(copyString,s);
while(*copyString!='\0')
*s=*copyString;
s++;
copyString++;
*s=' ';
s++;
*s='\0';
一.选择:
1.给出以下定义:
char acX[ ]= "abcdefg";
char acY[ ]= {'a','b','c','d','e','f','g'};
则正确的叙述为( )
A) 数组acX和数组acY等价 B) 数组acX和数组acY的长度相同
C) 数组acX的长度大于数组acY的长度 D) 数组acX的长度小于数组acY的长度
答案:C
2.
void example(char acHello[])
printf("%d", sizeof(acHello));
return;
void main()
char acHello[] = "hello";
example(acHello);//数组名称作参数,传的是地址,一个地址占四个字节
return;
的输出是
A 4 B 5 C 6 D不确定
答案:A
3. 有以下程序段
char acArr[]= "ABCDE";
char *pcPtr;
for(pcPtr = acArr; pcPtr acArr + 5; pcPtr++)
printf("%s\n", pcPtr);
return;
输出结果是( )
A) ABCD B) A C) E D) ABCDE
B D BCDE
C C CDE
D B DE
E A E
答案:D
4.在中断中,不能同步获取信号量,但是可以释放信号量。
A.正确 B.错误
答案:A
5.以下叙述中不正确的是( )
A) 在不同的函数中可以使用相同名字的变量
B) 函数中的形式参数是局部变量
C) 在一个函数内定义的变量只在本函数范围内有效
D) 在一个函数内的复合语句中定义的变量在本函数范围内有效(复合语句指函数中的成对括号构成的代码)
答案:D
6.设有如下定义:
unsigned long pulArray[] = {6, 7, 8, 9, 10};
unsigned long *pulPtr;
则下列程序段的输出结果为( )
pulPtr = pulArray;
*(pulPtr + 2) += 2;
printf ("%d,%d\n", *pulPtr, *(pulPtr + 2));
A)8,10 B)6,8 C)7,9 D)6,10
答案:D
7. 定义结构体时有下面几种说法,请指出正确的(多选):______
A、结构体中的每个部分,更好进行四字节对齐;
B、结构体的总长度更好是四字节对齐;
C、结构中成员的存放不用考虑字节对齐情况;
答案:A、B
8.void example()
int i;
char acNew[20];
for(i = 0; i 10; i++)
acNew[i] = '0';
printf("%d\n", strlen(acNew));
return;
的输出为( )
A 0 B 10 C 11 D不确定
答案:D
9.switch(c)中的c的数据类型可以是char、long、float、unsigned、bool. ( )
A. 正确 B. 错误
答案:B
10. *** 上传输的字节序默认是大字节的,如果主机是小字节序,在 *** 通信时则须进行字节序转换;如果主机是
大字节序,为了程序的一致性及可移植性,更好也在程序中加上字节序转换的操作(空操作)。
A. 正确 B.错误
答案:A
11. struct stu
int num;
char name[10];
int age;
void fun(struct stu *p)
printf("%s\n", (*p).name);
return;
void main()
struct stu students[3]={ {9801,"Zhang",20},
{9802,"Wang",19},
{9803,"Zhao",18} };
fun(students + 2);
return;
输出结果是( )
A) Zhang B)Zhao C) Wang D) 18
答案:B
12.以下程序运行后,输出结果是( )
void main( )
char *szStr = "abcde";
szStr += 2;
printf("%lu \n",szStr);
return;
A cde B 字符c的ASCLL码值
C "abcde"这个常串中字符c所在的地址 D 出错
答案:C
13. 在X86下,有下列程序
#include stdio.h
void main()
union
int k;
char i[2];
}*s,a;
s = a;
s-i[0] = 0x39;
s-i[1] = 0x38;
printf("%x\n", a.k);
输出结果是( )
A) 3839 B) 3938 C) 380039 D) 不可预知
答案:D
14. 全局变量可以定义在被多个.C文件包含着的头文件中。
A. 正确 B. 错误
答案:B
15.void example()
int i;
char acNew[20] = {0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
for(i = 0; i 10; i++)
acNew[i] = '0';
printf("%d\n", strlen(acNew));
return;
的输出为:
A 0 B 10 C 11 D不确定
答案:B
16.下列定义正确的有(多选):( )
A: char *pcPtr = "abcd";
B: char pc[4]= "abcd";
C: char pc[] = "abcd";
D: char pc[] = 'abcd';
E: char pc[] = {'a','b','c','d','\0'};
F: char pc[] = 'a' 'b' 'c' 'd';
答案:ACE
17.在函数内部定义的变量(静态变量、寄存器变量等特殊变量除外)的内存是在栈内存中,所以在定义函数内部的变量的时候,一定要保证栈不能够溢出。如果临时变量
占用空间较大,应该使用内存申请的方式,这样该变量指向的内存就是在堆内存中了。
A. 正确 B. 错误
答案:A
18.局部变量可以和全局变量重名,编译的时候不会出现错误,但一旦不小心,就可能导致使用错误变量,所以在定时局部变量的时候,不要和全局变量重名。
A. 正确 B. 错误
答案:A
19.设有以下宏定义:
#define N 3
#define Y(n) ((N+1)*n) /*这种定义在编程规范中是严格禁止的*/
则执行语句:z = 2 * (N + Y(5 + 1));后,z的值为( )
A) 出错 B) 42 C) 48 D)54
答案:C
20. int *(*ptr)();
则以下叙述中正确的是( )
A) ptr是指向一维组数的指针变量
B) ptr是指向int型数据的指针变量
C) ptr是指向函数的指针,该函数返回一个int型数据
D) ptr是指向函数的指针,该函数的返回值是指向int型数据的指针
答案:D
21. 0x12345678 在采用BigEndian中内存的排列顺序是______,在采用LittleEndian内存中的排列顺序是_______.
(答案从左到右内存地址依次增加)
A.12 34 56 78 B.34 12 78 56
C.78 56 34 12 D.56 78 12 34
答案:A C
二、填空:
1. .struct tagAAA
unsigned char ucId:1;
unsigned char ucPara0:2;
unsigned char ucState:6;
unsigned char ucTail:4;
unsigned char ucAvail;
unsigned char ucTail2:4;
unsigned long ulData;
}AAA_S;
问:AAA_S在字节对齐分别为1、4的情况下,占用的空间大小是多少?
答案:9 12
2.typedef struct tagTest
UCHAR ucFlag;
ULONG ulLen;
}TEST_S;
TEST_S test[10];
四字节对齐方式时: sizeof(TEST_S) = ______, sizeof(test)________.
答案:8 80
3
char acHello[] = "hello\0world";
char acNew[15] = {0};
strcpy(acNew,acHello);
strlen(acNew) = _____
sizeof(acHello) = ______
答案:5 12
4.#pragma pack(4)/*编译选项,表示4字节对齐*/
int main(int argc, char* argv[])
struct tagTest1
short a;
char d;
long b;
long c;
struct tagTest2
long b;
short c;
char d;
long a;
struct tagTest3
short c;
long b;
char d;
long a;
struct tagTest1 stT1;
struct tagTest2 stT2;
struct tagTest3 stT3;
printf("%d %d %d", sizeof(stT1), sizeof(stT2), sizeof(stT3));
return 0;
#pragma pack()(编译选项结束)
请问输出结果是:_________
答案:12 12 16
5. enum ENUM_A
X1,
Y1,
Z1 = 5,
A1,
B1
enum ENUM_A enumA = Y1;
enum ENUM_A enumB = B1;
请问 enumA = ____; enumB = ______;
答案:1 7
6.以下程序的输出结果是________.
#include stdio.h
int fun(int x,int y)
static int m = 0;8
static int i = 2;3
i += m + 1;12
m = i + x + y;
return m;
void main()
int j = 4;
int m = 1;
int k;
k = fun(j, m);
printf("%d,", k);
k=fun(j, m);
printf("%d\n", k);
return;
答案:8 17
7.以下程序的输出结果为________
#define CIR(r) r*r /*请注意这种定义的缺陷,不允许这么定义*/
void main()
int a = 1;
int b = 2;
int t;
t = CIR(a + b);
printf("%d\n", t);
return;
答案:5
8.在VRP中,实现了strncpy类似的函数,定义如下:
#define CHAR char
#define ULONG unsigned long
#define VOID void
#define MACRO_COPYWORLDLENGTH 4
CHAR *VOS_strncpy(CHAR *pcDest, const CHAR *szSrc, ULONG ulLength)
CHAR *pcPoint = pcDest;
if(( NULL == szSrc ) || ( NULL == pcDest ) ))
return NULL;
while(ulLength (*pcPoint = *szSrc))/*这里采用了在判断语句中赋值的方式(*pcPoint = *szSrc),建议尽量不使用*/
pcPoint++;
szSrc++;
ulLength--;
if(!ulLength)
*pcPoint = '\0';
return pcDest;
VOID main(VOID)
CHAR szStrBuf[ ] = "1234567890";
CHAR szStrBuf1[ ] = "1234567890";
CHAR *szHelloWorld = "Hello World!";
strncpy(szStrBuf, szHelloWorld, MACRO_COPYWORLDLENGTH);
VOS_strncpy(szStrBuf1, szHelloWorld, MACRO_COPYWORLDLENGTH);
printf("%s %s", szStrBuf, szStrBuf1);
程序的输出结果为________
答案:Hell567890 Hell
9.
char acHello[] = "hello\0world";
char acNew[15] = {0};
memcpy(acNew,acHello,12);
strlen(acNew) = _____
sizeof(acHello) = _____
答案:5 12
10. typedef struct Head
UCHAR aucSrc[6];
ULONG ulType;
} HEAD_S;
在强制一字节对齐情况下,请指出sizeof(HEAD_S) = ________;
在强制二字节对齐情况下,请指出sizeof(HEAD_S) = ________;
在强制四字节对齐情况下,请指出sizeof(HEAD_S) = ________;
答案:10 10 12
11.union tagAAAA
struct
char ucFirst;
short usSecond;
char ucThird;
}half;
long lI;
}number;
struct tagBBBBB
char ucFirst;
short usSecond;
char ucThird;
short usForth;
}half;
struct tagCCCC
struct
char ucFirst;
short usSecond;
char ucThird;
}half;
long lI;
在字节对齐为1下,sizeof(union tagAAAA)、sizeof(struct tagBBBBB)、sizeof(struct tagCCCC)是____ ____ _____
在字节对齐为4下,sizeof(union tagAAAA)、sizeof(struct tagBBBBB)、sizeof(struct tagCCCC)是____ ____ _____
答案:4 6 8
8 8 12
12.struct tagABC
char cB;
short sC;
char cD;
long lA;
}*pAbc;
pAbc = 0x100000;
那么pAbc+0x100 = 0x_________; (ULONG)pAbc + 0x100 = 0x_________;(ULONG *)pAbc + 0x100 = 0x_________;(char *)pAbc + 0x100 = 0x_______;
答案:100C00 100100 100400 100100
13.unsigned long FUNC_C ( unsigned long ulAction )
unsigned long ulResult = 0 ;
switch ( ulAction )
case ACTION_A:
ulResult += 1 ;
break ;
case ACTION_B:
ulResult += 1 ;
default:
ulResult += 1 ;
printf( "ulResult = %u", ulResult ) ;
return ulResult ;
当输入为ACTION_B时,输出结果为: ulResult = _________;
答案:2(因为此分支没有break分支)
14.下面的代码中,函数Test执行完毕后,打印的结果是 _____。
unsigned long g_ulGlobal = 0;
void GlobalInit(unsigned long ulArg)
ulArg = 0x01;
return;
void Test()
GlobalInit(g_ulGlobal);
printf("%lu", g_ulGlobal);
return;
答案:0
15.以下程序的输出的结果是___________
int x = 3;
void incre();
void main()
{ int i;
for (i = 1; i x; i++)
incre();
return;
void incre()
static int x = 1;
x *= (x + 1);
printf("%d ",x);
return;
答案:2 6
16.以下程序的输出的结果是___________
#pragma pack(4)/*四字节对齐*/
int main(int argc, char* argv[])
unsigned char puc[4];
struct tagPIM
unsigned char ucPim1;
unsigned char ucData0:1;
unsigned char ucData1:2;
unsigned char ucData2:3;
}*pstPimData;
pstPimData = (struct tagPIM *)puc;
memset(puc, 0, 4);
pstPimData-ucPim1 = 1;
pstPimData-ucData0 = 2;
pstPimData-ucData1 = 3;
pstPimData-ucData2 = 4;
printf("%02X %02X %02X %02X\n", puc[0], puc[1], puc[2], puc[3]);
return 0;
#pragma pack()/*恢复缺省对齐方式*/
答案:01 26 00 00
17.
char *pcColor = "blue1" ;
char acColor[] = "blue1" ;
strlen(pcColor) = _____
strlen(acColor) = _____
sizeof(pcColor) = _____
sizeof(acColor) = _____
答案:5 5 4 6
18.
char str[] = "\\\0";
char *p = str;
int n = 1000;
请计算
sizeof (str ) = ____________
sizeof ( p ) = ______________
sizeof ( n ) = ______________
答案:3 4 4
19.UCHAR *pucCharArray[10][10];
typedef union unRec
ULONG ulIndex;
USHORT usLevel[6];
UCHAR ucPos;
}REC_S;
REC_S stMax,*pstMax;
四字节对齐方式时: sizeof(pucCharArray) = __指针的数组,每个指针的地址都是4字节____, sizeof(stMax)=_______, sizeof(pstMax)=__地址______,sizeof(*pstMax)=________.
答案:400 12 4 12
20.typedef union unHead
UCHAR aucSrc [6];
struct tagContent
UCHAR ucFlag[3];
ULONG ulNext;
}Content;
}HEAD_S;
32CPU,VC编译环境下:
在强制一字节对齐情况下,请指出sizeof(HEAD_S) = ________;
在强制二字节对齐情况下,请指出sizeof(HEAD_S) = ________;
在强制四字节对齐情况下,请指出sizeof(HEAD_S) = ________;
答案:7 8 8
21.
UCHAR *pszTest = "hello";
UCHAR aucTest[] = "hello";
请问 sizeof(pszTest) = _____ , sizeof(*pszTest) = ______, sizeof(aucTest) = ______.
答案:4 1 6
22. struct BBB
long lNum;
char *pcName;
short sDate;
char cHa[2];
short sBa[6];
}*p;
p = 0x100000;
p + 0x1 = 0x____
(unsigned long)p + 0x1 = 0x______
(unsigned long *)p + 0x1 = 0x______
(char *)p + 0x1 = 0x______
答案:100018 100001 100004 100001
23.在4字节对齐的情况:
typedef struct tagRec
long lA1;
char cA2;
char cA3;
long lA4;
long lA5;
} REC_S;
void main(int argc, char *argv[])
REC_S stMax ;
printf("\r\n sizeof(stMax)= %d",sizeof(stMax));
return;
输出结果为:
sizeof(stMax)=____
答案:16
24.void main ()
unsigned long ulA = 0x11000000;
printf("\r\n%x",*(unsigned char *)ulA);
return;
输出结果为:
答案:0
三、指出下列程序中导致不能出现预期结果的唯一错误(不考虑编程规范错误)
1.下面程序用于输出用户输入的字符串。请指出其中的问题
#define OK 0
#define ERR 1
#define ERROR (-1)
#define BUFFER_SIZE 256
int GetMemory(char **ppszBuf, int num)
if( NULL == ppszBuf )
ASSERT(0);
return ERROR;
*ppszBuf = (char *)malloc(num);
if(NULL == *ppszBuf)
return ERROR;
return OK;
void Test(void)
char *pcStr = NULL;
if(OK == GetMemory(pcStr, BUFFER_SIZE))
scanf("%s",pcStr);/*这里假定BUFFER_SIZE足够大,不会导致越界*/
printf(pcStr);
free(pcStr);
return;
答案:要采用printf("%s", str)的形式打印,否则如果输入为%s, %d等形式可能会导致不可知现象。
2.此函数实现把32位IP地址(主机序)以字符串的方式打印出来,请找出代码中的错误:
char *IpAddr2Str(unsigned long ulIpAddr)
char szIpAddr[32];
(void)VOS_sprintf(szIpAddr, "%d.%d.%d.%d", ulIpAddr 24,
(ulIpAddr 16) 0xff, (ulIpAddr 8) 0xff, ulIpAddr 0xff);
return szIpAddr;
答案:函数的局部变量是存放在堆栈中的,此函数返回了堆栈中的地址,函数退出后堆栈中的内容不可用。
3.如下程序用于输出"Welcome Home"。请指出其中的错误:
void Test(void)
char pcArray[12];
strcpy(pcArray,"Welcome Home");
printf("%s!", pcArray);
return;
答案:数组越界。
4.如下程序用于把"blue"字符串返回,请指出其中的错误:
char *GetBLUE(void)
char* pcColor ;
char* pcNewColor;
pcColor = "blue";
pcNewColor = (char*)malloc(strlen(pColor));
if(NULL == pcNewColor)
return NULL;
strcpy(pcNewColor, pcColor);
return pcNewColor;
答案:申请内存空间不足,字符串结尾还有'\0'。
5.下面程序期望输出str = hello world,请指出其中的错误:
char * GetStr(char *p)
p = "hello world";
return p;
void main()
char *str = NULL;
if(NULL != GetStr(str))
printf("\r\n str = %s",str);
return;
答案:无法返回字符串,参数使用错误。
有一对兔子,从出生后第 3 个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?
兔子的规律为数列:
1, 1, 2, 3, 5, 8, 13, 21 ....
下面使用了迭代、递归和数组三种解法。
【代码一】使用迭代:
#include stdio.h
int main()
long f1=1, f2=1; // 兔子的数量
int i; // 循环次数
int n; // 要计算的月份
printf("输入要计算的月数:");
scanf("%d", n);
// 计算出循环次数
if(n%2==1){
n = (n+1)/2;
}else{
n = n/2;
for(i=1;i=n;i++){
printf("第%d个月有%d只\n", i*2-1, f1);
printf("第%d个月有%d只\n", i*2, f2);
f1=f1+f2; /*前两个月加起来赋值给第三个月*/
f2=f1+f2; /*前两个月加起来赋值给第三个月*/
return 0;
运行结果:
输入要计算的月数:10
第1个月有1只
第2个月有1只
第3个月有2只
第4个月有3只
第5个月有5只
第6个月有8只
第7个月有13只
第8个月有21只
第9个月有34只
第10个月有55只
【 *** 二】使用递归:
#includestdio.h
int Feibonacci(int n){
if(n==1||n==2)
return 1;
else
return Feibonacci(n-1)+Feibonacci(n-2);
int main(){
int n; // 要计算的月份
printf("输入要计算的月数:");
scanf("%d", n);
printf("%d个月的兔子总数为%d\n", n, Feibonacci(n));
return 0;
运行结果:
输入要计算的月数:10
10个月的兔子总数为55
递归看上去非常符合逻辑,但是这种递归效率是非常慢的,不信你计算20, 30, 40 个月的兔子数试试,明显比另外两种 *** 慢多了,具体分析请看:C语言用递归求斐波那契数,让你发现递归的缺陷和效率瓶颈
【代码三】使用数组
#includestdio.h
void main()
int a[100] ,i,n;
printf("请输入月数:");
scanf("%d",n);
a[0]=a[1]=1;
for(i=2;in;i++)
a[i]=a[i-1]+a[i-2];
printf("第%d个月的兔子为:%d\n", n, a[n-1]);
运行结果:
请输入月数:10
第10个月的兔子为:55
之一题:
#include stdlib.h
#include stdio.h
#include conio.h
#define RMAX 3
#define cMAX 4
void sumRow(int a[][cMAX],int b[])
for(int i = 0;i RMAX;i++)
b[i] = 0;
for(int j = 0;j cMAX;j ++)
b[i] += a[i][j];
void main()
int i,j,a[RMAX][cMAX],b[RMAX];
clrscr();
randomize();
for(i=0;iRMAX;i++)
for(j=0;jcMAX;j++)
a[i][j]=random(nMAX);
printf("产生随机数后数组如下所示:\n");
for(i=0;iRMAX;i++){
for(j=0;jcMAX;j++)
printf("%d ",a[i][j]);
printf("\n");
sumRow(a,b);
printf("每行的和为:\n");
for(i=0;iRMAX;i++){
printf("第%d行和为%d\n",i+1,b[i]);
第二题
#include stdlib.h
#include stdio.h
void replace(char *p,char ch)
while(*p != '\0'){
if(*p == ch)*p='x';
p ++;
void main()
char str[] = "I am a student in hunan university";
printf("请输入字符:");
char ch = getchar();
replace(str,ch);
printf("替换后的字符串为:%s\n",str);
第三题
#include stdlib.h
#include stdio.h
#include string.h
#define LEN 20
void sort(char str[][LEN],int n)
for(int i = 0;i n;i ++)
for(int j = 0;j n-1-i;j ++)
if(strcmp(str[j],str[j+1]) 0)
char s[LEN];
strcpy(s,str[j]);
strcpy(str[j],str[j+1]);
strcpy(str[j+1],s);
void main()
char str[][LEN] = {"student","worker","teacher","doctor"};
sort(str,4);
printf("排序后的字符串数组为:\n");
for(int i = 0;i 4;i ++)
printf("%s\n",str[i]);
据海峡网 二0 二 一年 一0月 二0日 一 七: 四0:0 二的消息 报导,微专网友@ 爆料。 安然 夜光降 之际,事宜 ,正在网上炒患上满城风雨,激发 齐网冷议! 据悉,乌客逃款之后被报导了几回 。推测 第六百八十八章追港者第六百八十九章奚弄 第六百。相对于那个账号是他的。 1、...
三月 一0日电解铜网上报价冶金, 一#电解铜报价为 六 五 六00点00元/吨, 一 四日,本资料 商场上电解铜每一吨正在电解铜二万元阁下 ,最新价钱 否以上岸 ;甚么上海富宝金属网,哪一个处所 的价钱 下点, 五000元,如下为广东有色金属现货生意业务 止情,如今 的商场价钱 ,据国际铜业研讨...
二0 二 一. 五. 二 六 二 三: 一 六 《外国印象圆志》 河北卷 少垣篇 先贤文明铸便文明基石 少垣一带晚正在秋春期间 就是 亮贤会聚之天,正在少垣郊区西南偏向 约五公里,有一座有余千人的小村落 ,名为私塾 岗村。它的名字,便起源 于一段贤者美谈 。 一日,孔子带着寡门生 途...
国产SUV再加新成员 新圣达菲卖 一0. 一 八- 一 二. 五 八万元 铁扇私主 揭橥 于 牛车网 二0 一 四. 一 一. 二0 一 五:0 二 华泰新圣达菲正在本年 的广州车铺邪式上市,新车异时拉没搭载 一. 五T汽油以及 二.0T柴油柴油二种动员 机的 ...
影响没有年夜 。上市。的需供而设计。新华富时外国A 五0指数由,需供所拉没的及时 否生意业务 指数,需供所拉没的及时 否生意业务 指数。新华富时外国A 五0指数是及时 否生意业务 指数及时 ,QFII。 否以解决 孬账户那作一脚 二000美圆上高,后市仍有富时区间震动 否能。a 五0e0 一- 一 ...
脚机是年夜 野一样平常 生涯 外必弗成 长的电子产物 了,不论是正在哪皆离没有谢脚机。 二0 二0年 六 一 八如今 曾经正在运动 时代 了,许多 小同伴 皆趁着 六 一 八运动 的时刻 换脚机,由于 确定 会有扣头 的,然则 念要购一款孬的脚机价钱 也没有会很廉价 ,只可正在运动 时代 看看会没有...