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;

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

相关推荐
yong99901 分钟前
基于MATLAB的雷达数字信号处理
开发语言·matlab·信号处理
SilentSamsara2 分钟前
HTTP 客户端实战:httpx/重试/限速/连接池/中间件设计
开发语言·网络·python·http·青少年编程·中间件·httpx
填满你的记忆3 分钟前
《动态规划-基础篇》
算法·动态规划·力扣
进击的荆棘4 分钟前
优选算法——队列+宽搜
数据结构·c++·算法·leetcode·bfs·队列
黎阳之光6 分钟前
虚实同源·数智治水:黎阳之光视频孪生,重构智慧水务新范式
运维·物联网·算法·安全·数字孪生
江屿风8 分钟前
C++OJ题经验总结(竞赛)4
开发语言·c++·笔记·算法·dp·双指针
Deep-w8 分钟前
【MATLAB】微电网四DG逆变器下垂策略与分布式MPC协同控制仿真分析
开发语言·分布式·算法·matlab
酉鬼女又兒8 分钟前
零基础入门计算机网络:定义、分类与核心性能指标
开发语言·计算机网络·考研·青少年编程·职场和发展·php
手写码匠9 分钟前
华为云Flexus+DeepSeek征文|万字实战:MaaS 推理服务 + Dify 高可用部署 + AI Agent 开发全流程
人工智能·深度学习·算法·aigc
yu85939589 分钟前
基于卡尔曼滤波器的集中式机器人轨迹定位算法
算法·机器人