c语言基础测试题--牧码南山招新检测题

1.请为下列代码段添加注释

#include<stdio.h>

int main(){
    printf("To c , or not to c , that is the question ./n");
    return 0;
} 

答案

#include<stdio.h>  //头文件 包含了标准输入/输出库的相关信息  

int main(){  //主函数 必不可少  
    printf("To c , or not to c , that is the question ./n"); //printf函数功能是输出信息 /n用于换行 
    return 0;  //程序终止时向操作系统返回值0  
} 

2. Dr.张 编写了一个demo01.c 程序 ,若想生成可执行文件 , 需经过

第一步: ___________ 
第二步:___________ ,生成 ___________ 后缀的文件
第三步:___________ ,生成 ___________ 后缀的文件

答案
预处理
编译 .obj
连接 .exe

3.写出两种注释方法

作答区:







答案
第一种:

//  int a=8;

第二种:

/*
  int a=8;
  int b=10;
*/

4.常量分为整型常量 、 实型常量 和 字符型常量 ,字符型常量在计算机中是以 ___________ 形式存储的 .

作答区:____________________________________________________________
答案
ascii码

5.字符'a'的ascii码是___________, 字符'A'的ascii码是___________.

作答区:_____________________________ _______________________________
答案
97,65

6.转义字符

转义字符|字符值
---|:--:|---:
'|
"|
?|
\||
\a|
\b|
\f|
\n|
\r|
\t|
\v|
\o、\oo|
\xh[h...]|
答案
转义字符|字符值
---|:--:|---:
'|'
"|"
?|?
\||
\a|警告
\b|退格
\f|换页
\n|换行
\r|回车
\t|水平制表符
\v|垂直制表符
\o、\oo|与该八进制码对应的ascii字符
\xh[h...]|与该十六进制码对应的ascii字符

7.常见数据类型的存储空间与所占字节数(默认带符号数)

类型|字节数
---|:--:|---:
int|
short|
long|
long long|
float|
double|
long double|
char|

答案
类型|字节数
---|:--:|---:
int|2
short|1
long|4
long long|8
float|4
double|8
long double|8
char|1

8.程序改错

#include<stdio.h>

int mian(){
    double a , b , c , disc , x1 , x2 , p , q;
    scanf("%f%f%f", a , b , c);
    disc = b*b-4*a*c;
    p=-b/(2.0*a);
    q=sqrt(disc)/(2.0*a);
    x1 = p+q;
    x2 = p-q;
    printf("x1 = %7.2f\nx2 = %7.2f\n",x1,x2)
    return 0;
} 

答案

#include<stdio.h>
#include<math.h>

int mian(){
    double a , b , c , disc , x1 , x2 , p , q;
    scanf("%lf%lf%lf", &a , &b , &c);
    disc = b*b-4*a*c;
    p=-b/(2.0*a);
    q=sqrt(disc)/(2.0*a);
    x1 = p+q;
    x2 = p-q;
    printf("x1 = %7.2f\nx2 = %7.2f\n",x1,x2);
    return 0;
} 

9.请完善/改正下述宏定义:

#define MAX(a,b) a > b ? a : b
作答区:____________________________________________________________

SEC_PER_YEAR 用宏定义来表示一年中有几秒
#define SEC_PER_YEAR (365*24*60*60)
作答区:____________________________________________________________
答案

#define MAX(a,b) (((a) > (b)) ? (a) : (b))
#define SEC_PER_YEAR (365*24*60*60)UL

解析
本题的四个要点
1.不要吝啬括号
2.宏定义中当第一个数字出现在程序中,它的类型默认是int
3.3652460*60 超过了int的范围
4.强制类型转换成UL类型(无符号长整型)

10.判断题:c语言是区分大小写的 ( )

作答区:____________________________________________________________
答案

11.简述标识符命名规范

作答区:




答案
1.由字母、数字、下划线组成
2.数字不能放第一位

12.判断下列哪些是C语言的关键字

(a) for
(b) If
(c) main
(d) printf
(e) while
作答区:____________________________________________________________
答案
√×√√√

13.下面的printf函数调用产生的输出结果分别是什么?

printf("%10.6f\n",30.253);
printf("%-7.4f\n",83.162);

作答区:




答案

 30.253000
83.1620

14.假设scanf函数调用的格式如下:

scanf("%f%d%f\n",&x,&i,&y);
如果用户输入:
12.3 45.6 789
则你预测调用执行后,x,i,y的值分别是:
作答区:____________________________________________________________
答案
x=12.3
i=45
y=0.6

15.读代码,预测输出值

#include<stdio.h>

int main(){
    int i=1 , j=1;
    printf("i is %d\n",++i);
    printf("i is %d\n", i);
    printf("j is %d\n",j++);
    printf("j is %d\n", j);
    return 0;
} 

作答区:




答案

i is 2
i is 2
j is 1
j is 2

16.编程题:编写一个程序,要求用户输入一个两位数,然后按位数的逆序打印输出,程序会话应类似下面这样:

Enter a two-digit number: 28
The reversal is: 82

作答区:






















17.编程题:利用switch编写一个程序,把用数字表示的成绩转化为字母表示的等级,程序会话应类似下面这样:

Enter numerical grade: 84
Letter grade: B
依据 [ A:90~100 B:80~89 C:70~79 D:60~69 F:0~59 ]

作答区:
































参考答案

/* 用数字表示的成绩转化为用字母表示的等级*/ 
#include<stdio.h>
int main()
{
    int a,b;
    printf("Enter numerical grade:");
    scanf("%d",&a);
    if(a>=0 && a<=100)
    {
     a=a/10;
    switch(a)
    {
        case 0:
        case 1:
        case 2:
        case 3:
        case 4:
        case 5:printf("Letter grade: F");break;
        case 6:printf("Letter grade: D");break; 
        case 7:printf("Letter grade: C");break; 
        case 8:printf("Letter grade: B");break;
        case 9: case 10: printf("Letter grade: A");break;   
    }
    }
    else
      printf("wrong");
    return 0;
}

18. 说说do while 和 while 的异同

19. 编写程序,要求用户输入两个整数,然后计算并显示这两个整数的最大公约数(GCD),程序会话应类似下面这样:

Enter two integers:12 28
Greaest common divisor: 4
提示:求最大公约数的经典算法是Euclid算法,方法如下:分别让变量m和n存储两个数的值。如果n为0,那么停止操作,m中的值是GCD;否则计算m除以n的余数,把n保存到m中,并把余数保存到n中,重复上述过程,每次都先判定n是否为0.

作答区:










































参考答案

#include<stdio.h>
int main()
{
    int m,n,c,min;
    printf("Enter two integers:");
    scanf("%d %d",&m,&n);
    if(m==0 && n!=0)
      printf("Greatest common divisor: %d\n",n);
    if(n==0 && m!=0)
      printf("Greatest common divisor: %d\n",m);
    if(m!=0 && n!=0)
    {
    while(m!=0 && n!=0)
    {
    if(m>n)
    {
        c=m%n;
        min=n;
        
    }
    else
    {
        c=n%m;
        min=m;
        
        
    }
    n=min;
    m=c;
    
    }
    printf("Greatest common divisor: %d\n",n);
    }
    if(m==0 && n==0)
      printf("非法输入");  
    return 0;    
}

20. 强制类型转换:修改下述代码

#include<stdio.h>
int main()
{
    long i;
    int j = 1000;
    i = j*j;
    return 0;
}

作答区:










答案

#include<stdio.h>
int main()
{
    long i;
    int j = 1000;
    i = (long)j*j;
    return 0;
}

21. 用文字或代码解释sizeof()

作答区:



答案

文字:sizeof运算符允许程序存储指定类型值所需空间的大小
代码:printf("Size of int:%lu\n",(unsigned long)sizeof(int));

22. 编程题:打印出所有的“水仙花数”,所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身

作答区:


























答案

#include <stdio.h>

int main()
{
    int i,count = 0;
    int i2,i1,i0;
    for (i=100;i<1000;i++)
    {
        i2 = i / 100;
        i1 = i / 10 % 10;
        i0 = i % 10 ;
        
        if (i2 * i2 * i2 + i1 * i1 * i1 + i0 * i0 * i0 == i)
        {
           printf("%d ",i);
           count ++;
        }
    
    }
    printf("\nthe count is:%d\n",count);
    
    return 0;
}

23.编程题:递归地计算n! 提示:n!=n*(n-1)!

作答区:


























答案

#include<stdio.h>
int fact(int n);
int main()
{
    int n;
    n = fact(10);
    printf("%d\n",n);
    return 0;
}

int fact(int n){
    if(n <= 1)
        return 1;
    else
        return n*fact(n-1); 
}

23. 编程题:手写任意一个排序算法

作答区:


























24. 请声明一个指针变量p

25. 请初始化上述你声明的指针变量指向一个对象i

26. 将上述两个问题合并成一句代码,在声明变量的同时进行初始化

27. 预测结果:

#include<stdio.h>
int main()
{
    int *p,i;
    p = &i;
    i=1;
    printf("%d\n",i);
    printf("%d\n",*p);
    *p=10;
    printf("%d\n",i);
    printf("%d\n",*p);
    return 0;
}

作答区:____________________________________________________________

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,490评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,581评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,830评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,957评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,974评论 6 393
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,754评论 1 307
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,464评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,357评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,847评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,995评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,137评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,819评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,482评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,023评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,149评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,409评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,086评论 2 355

推荐阅读更多精彩内容