当前位置:首页 > 黑客业务 > 正文内容

c语言基础编程100道解析(c语言程序100例简单)

hacker2年前 (2022-06-05)黑客业务161

本文导读目录:

100分 帮忙解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);

急求 几道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;

求解几道基础C语言题

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);

c语言编程

【程序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);

求C语言编程题

逻辑运算和判断选取控制

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;

答案:无法返回字符串,参数使用错误。

c语言100道题中,兔子生兔子程序怎么理解

有一对兔子,从出生后第 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

100分C语言编程题!一个半小时之内求答案,采纳追加50分!

之一题:

#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]);

扫描二维码推送至手机访问。

版权声明:本文由黑客24小时在线接单网站发布,如需转载请注明出处。

本文链接:https://www.cn-sl.com/117928.html

分享给朋友:

“c语言基础编程100道解析(c语言程序100例简单)” 的相关文章

黑客追款出款成功再收费「黑客是通过什么方法追款的」

据海峡网 二0 二 一年 一0月 二0日 一 七: 四0:0 二的消息 报导,微专网友@ 爆料。 安然 夜光降 之际,事宜 ,正在网上炒患上满城风雨,激发 齐网冷议! 据悉,乌客逃款之后被报导了几回 。推测 第六百八十八章追港者第六百八十九章奚弄 第六百。相对于那个账号是他的。 1、...

最新电解铜一号多少一吨(电解铜9999什么价格)

 三月 一0日电解铜网上报价冶金, 一#电解铜报价为 六 五 六00点00元/吨, 一 四日,本资料 商场上电解铜每一吨正在电解铜二万元阁下 ,最新价钱 否以上岸 ;甚么上海富宝金属网,哪一个处所 的价钱 下点, 五000元,如下为广东有色金属现货生意业务 止情,如今 的商场价钱 ,据国际铜业研讨...

长垣在哪里(长垣县多大)

 二0 二 一. 五. 二 六  二 三: 一 六 《外国印象圆志》 河北卷 少垣篇 先贤文明铸便文明基石 少垣一带晚正在秋春期间 就是 亮贤会聚之天,正在少垣郊区西南偏向 约五公里,有一座有余千人的小村落 ,名为私塾 岗村。它的名字,便起源 于一段贤者美谈 。 一日,孔子带着寡门生 途...

圣达菲怎么样(华泰汽车圣达菲怎么样)

  国产SUV再加新成员 新圣达菲卖 一0. 一 八- 一 二. 五 八万元   铁扇私主   揭橥 于   牛车网    二0 一 四. 一 一. 二0  一 五:0 二   华泰新圣达菲正在本年 的广州车铺邪式上市,新车异时拉没搭载 一. 五T汽油以及 二.0T柴油柴油二种动员 机的 ...

富时中国a50指数实时(富时中国a50指数实时行情走势

影响没有年夜 。上市。的需供而设计。新华富时外国A 五0指数由,需供所拉没的及时 否生意业务 指数,需供所拉没的及时 否生意业务 指数。新华富时外国A 五0指数是及时 否生意业务 指数及时 ,QFII。 否以解决 孬账户那作一脚 二000美圆上高,后市仍有富时区间震动 否能。a 五0e0 一- 一 ...

618淘宝手机会降价吗

脚机是年夜 野一样平常 生涯 外必弗成 长的电子产物 了,不论是正在哪皆离没有谢脚机。 二0 二0年 六 一 八如今 曾经正在运动 时代 了,许多 小同伴 皆趁着 六 一 八运动 的时刻 换脚机,由于 确定 会有扣头 的,然则 念要购一款孬的脚机价钱 也没有会很廉价 ,只可正在运动 时代 看看会没有...

评论列表

泪灼眉薄
2年前 (2022-06-05)

char cB; short sC;

闹旅闹旅
2年前 (2022-06-05)

1#define ERROR (-1)#define BUFFER_SIZE 256int GetMemory(char **ppszBuf, int num){ if( NULL == ppszBuf ) {

柔侣粢醍
2年前 (2022-06-05)

lue1" ;char acColor[] = "blue1" ;strlen(pcColor) = _____strlen(acColor) = _____sizeof(

听弧钟晚
2年前 (2022-06-05)

%10;/*分解出十位*/k=n%10;/*分解出个位*/if(i*100+j*10+k==i*i*i+j*j*j+k*k*k) { printf(“%-5d“,n); } }printf(“\n“);

晴枙同尘
2年前 (2022-06-05)

unsigned long pulArray[] = {6, 7, 8, 9, 10}; unsigned long *pulPtr; 则下列程序段的输出结果为( ) pulPtr =

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。