C语言--每日五道练习题--Day13

第一题

1、设变量已正确定义,以下不能统计出一行中输入字符个数(不包含回车符)的程序段是
A: n=0;while(ch=getchar()!='\n')n++;

B: n=0;while(getchar()!='\n')n++;

C: for(n=0;getchar()!='\n';n++);

D: n=0;for(ch=getchar();ch!='\n';n++);

答案及解析 D

getchar这个函数,是用来在读我们键盘输入的字符的。

所以题中说不包含回车符,循环的条件就是当我们getchar取到的字符不是回车;

那么ABC都可以;

D选项是把getchar取到的字符给ch,for循环初始化的语句只会执行一次,所以无法统计出一行输入的字符个数的,是一个死循环;

第二题

2、运行以下程序后,如果从键盘上输入 65 14<回车> ,则输出结果为( )

cpp 复制代码
int main()
{
    int m, n;
    printf("Enter m,n;");
    scanf("%d%d", &m,&n);
    while (m!=n) //1
    {
        while(m>n) 
        {
            m=m-n; //2
        }
        while(n>m) 
        {
            n=n-m; //3
        }

    }
    printf("m=%d\n",m);
    return 0;
}

A: 3

B: 2

C: 1

D: 0

答案及解析 C

这个就是挨个算,细心就行。

第三题

3、若运行以下程序时,从键盘输入 ADescriptor<回车> ,则下面程序的运行结果是( )

cpp 复制代码
#include <stdio.h>
int main()
{
    char c;
    int v0 = 0;
    int v1 = 0,
    int v2 = 0;
    do
    {
        switch(c=getchar())
        {
            case'a':
            case'A':
            case'e':
            case'E':
            case'i':
            case'I':
            case'o':
            case'O':
            case'u':
            case'U':
                v1 += 1;
            default:
                v0 += 1;
                v2 += 1;
        }
    }while(c != '\n');
    printf("v0=%d,v1=%d,v2=%d\n",v0,v1,v2);
    return 0;
}

A: v0=7,v1=4,v2=7

B: v0=8,v1=4,V2=8

C: v0=11,v1=4,v2=11

D: v0=12,v1=4,v2=12

答案及解析 D

这里考察的就是我们对getchar函数,switch语句和do-while语句的认识,do-while语句的循环条件在后面,所以是比正常结束循环多执行一次,也就是说当getchar取到回车字符的时候,do-while会执行,最后判断。

switch语句中的case和default语句,如果我们在每个case语句和default后面没有break语句,就会继续执行,直到switch执行结束或者遇到break语句才停下来。

所以答案是D

第四题

4、如下函数是求两个int数字最大公约数的,指出其中存在的问题【多选】( )

cpp 复制代码
int gcd(char x,char y)
{
    int min = x < y ? x : y;
    for (min = 0; min > 0; min--)
    {
        if (x % min = 0 && y % min = 0)
            return min;
    }
}

A: 参数类型不对

B: 循环变量min初值不对

C: 判断等于的符号不对

D: 返回类型不对

答案及解析 ABC

问题一:我们要求两个int数字的最大公约数,所以形参的类型必须是int类型,参数类型错误;

问题二:程序是定义了局部变量min,找的是x和y之间小的那个,之后让min--,看他们是否都可以整除min,所以for循环的初始值应该是min本身,如果是0,就找不到最大公约数了;

问题三:if语句中判断相等应该用==,不是=。' = '是赋值语句,语句恒为真,无法判断;
其实还有个问题就是只有在if语句成立才有返回值,不成立的话就没有返回值,这里看编译器自身,但是建议大家可以在没有最大公约数的时候,添加个返回值return -1;

第五题

5、执行下面的程序段,语句3的执行次数为( )

cpp 复制代码
for(i = 0; i <= n-1; i++) // (1)
{
    for(j = n; j > i; j--) // (2)    
    {
        state; // (3)
    }
}

A: n(n+2)/2

B: (n-1)(n+2)/2

C: n(n+1)/2

D: (n-1)(n+2)

答案及解析 C

这里我们找规律就OK了;第一次循环执行了n次,第二次n-1,......最后一次是1;

这个是等差数列:n+(n-1)+ ....+ 1;

等差数列的和就是语句三的执行次数;

相关推荐
fox_lht1 分钟前
第十四章 一个输入和输出项目:构建一个命令行程序
开发语言·后端·rust
郑州光合科技余经理6 分钟前
海外版外卖系统:如何快速搭建国际化外卖平台
java·开发语言·前端·人工智能·小程序·系统架构·php
Cheng小攸8 分钟前
协议分析与分析工具(一)
开发语言·php
CC数学建模8 分钟前
2026第八届中青杯全国大学生数学建模竞赛C题:情绪维度耦合约束的脑电信号情绪识别 (1)完整思路、代码、模型、文章,全网首发高质量分享!
python·算法·数学建模
玖玥拾11 分钟前
C/C++ 基础笔记(五)
c语言·c++·指针
Dillon Dong11 分钟前
【风电控制】双馈风机网侧高低穿控制策略——从VrtCal信号处理到状态机逻辑的完整解析
算法·变流器·风电控制·dfig
fox_lht11 分钟前
14.2.读文件
开发语言·后端·rust
codeejun11 分钟前
每日一Go-74、Go 云原生可观测性实战之OpenTelemetry 全链路采集:Trace + Metrics + Logs
开发语言·云原生·golang
下午写HelloWorld11 分钟前
同态加密(Homomorphic Encryption, HE)
人工智能·算法·密码学·同态加密
CC数学建模12 分钟前
2026第八届中青杯全国大学生数学建模竞赛B题:AI生成内容的质量评估与参数优化完整思路、代码、模型、文章,全网首发高质量分享!
python·算法·数学建模