【C语言】初阶测试 (带讲解)

 

目录

① 选择题

        1. 下列程序执行后,输出的结果为( )

2. 以下程序的输出结果是? 

3. 下面的代码段中,执行之后 i 和 j 的值是什么() 

4. 以下程序的k最终值是:

5. 以下程序的最终的输出结果为:

6. 下列描述中正确的是()

 7.C 语言规定,在一个源程序中,main函数的位置()

8.以下叙述不正确的是( )  

9.以下叙述正确的是( )。

10. 执行如下代码, c 的值是:()

 11. 假定 x 和 y 为 double 型,则执行 x=2 ; y=x+3/2; 后y的值为()

12. 以 下 for 循 环 的 执 行 次 数 是()

13. 若有定义语句: int year=1009 , *p=&year ;

14. 选择表达式 11|10 的结果(本题数值均为十进制) 

15. char a ; int b ; flat c ; double d ; 则表达式 a*b+d-c 值的类型为() 

②ACM编程题

1.求最小公倍数

2.倒置字符串


 

① 选择题

        1. 下列程序执行后,输出的结果为( )

#include 
int cnt=0;
int fib(int n){
cnt++;
if(n==0)
return 1;
else if(n==1)
return 2;
else
return fib(n-1)+fib(n-2);
}
void main()
{
fib(8);
printf("%d",cnt);
}

A 41

B 67

C 109

D 177 

【C语言】初阶测试 (带讲解)_第1张图片

总共算出有67次递归运算,每次进入fib()都会cnt++;所以选B 

2. 以下程序的输出结果是? 

int x = 1;

do{

printf("%2d\n",x++);

}while(x--); 

A 1

B 无任何输出

C 2

D 陷入死循环

x=1,进入,然后后置加加变成2,在进入while,变成1.如此死循环。选D 

3. 下面的代码段中,执行之后 i 和 j 的值是什么() 

int i=1;
int j;
j=i++

A 1,1

B 1,2

C 2,1

D 2,2

选C

4. 以下程序的k最终值是:

 int i = 10; 
int j = 20; 
int k = 3; 
k *= i + j;

 A 90

B 50

C 70

D 30

因为赋值操作符优先级较低,所以先运算i+j再*K 

5. 以下程序的最终的输出结果为:

int a=1; 
void test()
{ 
int a=2;
a+=1;
 }  
int main(){
test();
printf("%d\n",a);
return 0;
}

A 1

B 2

C 3

D 4 

局部变量出了作用域就销毁了,所以打印的是全局变量a,这里并没有将a的地址传过去。 

6. 下列描述中正确的是()

A 表示m>n为true或者mn&&m

B switch语句结构中必须有default语句
C 如果至少有一个操作数为true,则包含“]”运算符的表达式true

D if语句结构中必须有else语句

选C 

 7.C 语言规定,在一个源程序中,main函数的位置()

A 必须在最开始
B 必须在系统调用的库函数的后面
C 可以任意
D 必须在最后 

选C 

8.以下叙述不正确的是( )  


A  一个C源程序可由一个或多个函数组成
B  一个C源程序必须包含一个main函数
C   C程序的基本组成单位是函数
D   在C程序中,注释说明只能位于一条语句的后面 

 选D

9.以下叙述正确的是( )。

在C程序中,main函数必须位于程序的最前面
C程序的每行中只能写一条语句
C语言本身没有输入输出语句
在对一个C程序进行编译的过程中,可发现注释中的拼写错误 

选C 

10. 执行如下代码, c 的值是:()

int a=0,c=0;
do{
--c;
a=a-1;
}while(a>0);

A  0

B 1

C  -1

D 死循环 

c--等于-1; a = a-1  a 等于-1,while(-1>0) 为假,跳出循环,所以选C; 

 11. 假定 x 和 y 为 double 型,则执行 x=2 ; y=x+3/2; 后y的值为()

A 3.500000

B 3

C 2.000000

D 3.000000

3/2为整数1,  1+double型的x, 1+2.0 = 3.0;所以选D 

12. 以 下 for 循 环 的 执 行 次 数 是()

 for(x=0,y=0;(y=123)&&(x<4);x++); 

A 是无限循环

B 循环次数不定

C 4次

D 3次

y=123恒为真,只看x<4; 只有x =0,1,2,3一共四次循环就会跳出,所以选C 

13. 若有定义语句: int year=1009 , *p=&year ;

以下不能使变量 year 中的值增至 1010 的语句是 

A *p+=1;

B (*p)++;

C ++(*p)

D *p++ 

*p++ p会先跟++结合,就会跳到下一个整型地址,题目要的是通过&year修改值 ;选D

14. 选择表达式 11|10 的结果(本题数值均为十进制) 

A 11

B 10

C 8

D 2

| //按位或, 只要有一个为真就为真,1011和1010 | 后,结果为 1011;所以选A

15. char a ; int b ; flat c ; double d ; 则表达式 a*b+d-c 值的类型为() 

A float

B int

C char

D double 

两个不同类型进行计算时,会吧小的提 升成的,所以最后结果为double.选D

②ACM编程题

1.求最小公倍数

正整数A和正整数B 的最小公倍数是指 能被A和B整除的最小的正整数值,设计一个算法,求输入A和B的最小 公倍数。

输入描述: 输入两个正整数A和B。

输出描述: 输出A和B的最小公倍数。 

示例1: 输入 5 7 输出 35 

int main()
{
    long long a = 0;
    long long b = 0;

    scanf("%lld %lld", &a, &b);
    //求出a和b的较大值
    long long i = 1;
    while (i * a % b != 0)
    {
        i++;
    }

    printf("%lld\n", i * a);

    return 0;
}

 

2.倒置字符串

将一句话的单词进行倒置,标点不倒置。

比如 I like beijing. 经过函数后变为:beijing. like I

输入描述: 每个测试输入包含1个测试用例: I like beijing.

输入用例长度不超过100 输出描述: 依次输出倒置之后的字符串,以空格分割

示例1: 输入 I like beijing.

                输出 beijing. like I 

void reverse(char* left, char* right)
{
    while (left < right)
    {
        char tmp = *left;
        *left = *right;
        *right = tmp;
        left++;
        right--;
    }
}

int main() {
    char arr[101] = { 0 };
    //abcdef ghi qwer\0

    //scanf("%s", arr);
    //gets(arr);
    //scanf("%[^\n]s", arr);
    int ch = 0;
    int i = 0;
    while ((ch = getchar()) != '\n')
    {
        arr[i++] = ch;
    }
    int len = strlen(arr);

    //1. 逆序整个字符串
    reverse(arr, arr + len - 1);
    //2. 逆序每个单词
    char* cur = arr;
    while (*cur)
    {
        char* start = cur;
        while (*cur != ' ' && *cur != '\0')
        {
            cur++;
        }
        char* end = cur - 1;
        reverse(start, end);//逆序一个单词
        if (*cur == ' ')
            cur++;
    }
    printf("%s\n", arr);
    return 0;
}

 

【C语言】初阶已经全介绍了一遍,做完这套初阶测试,巩固,后续还会出每日一题【C语言】。

文中不足的地方,希望大佬指点改善 

 

你可能感兴趣的:(【C】,c语言,算法,开发语言,程序人生,学习)