C语言刷题(循环结构程序设计)

简介: C语言刷题(循环结构程序设计)

第一题

输入一行字符(使用getchar函数循环获取输入的每一个字符,直到回车字符结束循环),分别统计出其中的大写英文字母、小写英文字母、空格、数字和其他字符的个数。

解题思路如下:

  1. 首先,我们定义变量来统计大写英文字母、小写英文字母、空格、数字和其他字符的个数,初始值都为 0。
  2. 然后,使用 getchar 函数循环读取用户输入的字符,直到读取到回车字符 \n 为止。
  3. 在循环中,对于每个读取到的字符,通过条件语句判断它的类型:

如果字符在大写字母范围内(‘A’ 到 ‘Z’),则将大写字母计数加一。

如果字符在小写字母范围内(‘a’ 到 ‘z’),则将小写字母计数加一。

如果字符是空格,则将空格计数加一。

如果字符在数字范围内(‘0’ 到 ‘9’),则将数字计数加一。

否则,将其他字符计数加一。

  1. 最后,输出各个类型字符的个数。

介绍gether函数:

getchar 是一个标准库函数,用于从标准输入流(通常是键盘输入)中获取一个字符。getchar 函数不需要任何参数,每次调用都会从标准输入中读取下一个字符,并将其作为返回值返回。如果没有可用的字符(例如已经读到文件末尾或者出现了输入错误),则返回一个特殊值 EOF(End of File)。

通常情况下,getchar 函数会与循环结合使用,用来逐个读取用户输入的字符,直到满足某个条件退出循环。例如,可以使用 getchar 来实现逐字符处理用户输入的字符串,或者用于处理文本文件的内容。

#include <stdio.h>  
int main(){  
    int uppercase = 0;//初始化大写英文字母个数  
    int lowercase = 0;//初始化小写英文字母个数  
    int space = 0;//初始化空格字符个数  
    int digit = 0;//初始化数字字符个数  
    int other = 0;//初始化其他字符个数  
    char ch;  
    printf("请输入一行字符:\n");  
    //循环历经字符串每一个字符直到末端  
    while ((ch = getchar()) != '\n') {  
        if (ch >= 'A' && ch <= 'Z') {  
            uppercase++;  
        } else if (ch >= 'a' && ch <= 'z') {  
            lowercase++;  
        } else if (ch == ' ') {  
            space++;  
        } else if (ch >= '0' && ch <= '9') {  
            digit++;  
        } else {  
            other++;  
        }  
    }  
    //输出每个字符的个数  
    printf("大写英文字母个数:%d\n", uppercase);  
    printf("小写英文字母个数:%d\n", lowercase);  
    printf("空格个数:%d\n", space);  
    printf("数字个数:%d\n", digit);  
    printf("其他字符个数:%d\n", other);  
    return 0;  
}

第二题

水仙花数是各位数字立方之和等于数字本身的三位整数,编写程序求出所有的水仙花数并输出。

解题思路:

我们使用 for 循环遍历所有的三位数(从 100 到 999)。对于每个数字,我们使用 while 循环来依次计算它的各个位上数字的立方和。

在 while 循环中,我们将当前数字 temp 的个位数提取出来,并将其立方加到总和 sum 上,然后将 temp 除以 10,继续处理下一位数,直到 temp 变为 0。

完成 while 循环后,我们将 sum 与原始数字 num 进行比较。如果它们相等,则说明该数字是水仙花数,我们将其输出。

最后,我们输出所有的水仙花数。

#include <stdio.h>  
int main(){  
    int num = 0;//初始化要查询的数字  
    int diglit = 0;  
    int sum = 0;  
    printf("水仙花数有:\n");  
    //循环历经一遍100-999  
    for (num = 100; num < 999; num++) {  
        int temp = num;//创建一个变量用于寻找每一位数字、  
        //每一位的三次求和  
        while(temp>0){  
            diglit = temp%10;  
            sum+=diglit*diglit*diglit;  
            temp/=10;//防止程序死循环  
        }  
        if(num==sum){  
            printf("%d ",num);  
        }  
        sum = 0;//更新sum  
    }  
}

第三题

棋盘麦粒问题。在印度有一个古老的传说:舍罕王打算奖赏国际象棋的发明人——宰相达依尔。国王问他想要什么,他对国王说:“陛下,请您在这张棋盘的第 1 个小格里,赏给我 1 粒麦子,在第 2 个小格里给 2 粒,第 3 小格给 4 粒,像这样,后面一格里的麦粒数量总是前面一格里的麦粒数的 2 倍。请您把这样摆满棋盘上所有的 64 格的麦粒,都赏给您的仆人吧!”国王觉得这要求太容易满足了,于是令人扛来一袋麦子,可很快就用完了。当人们把一袋一袋的麦子搬来开始计数时,国王才发现:就是把全印度的麦粒全拿来,也满足不了那位宰相的要求。那么,宰相要求得到的麦粒到底有多少呢?假如体积为 1 立方米的麦粒约为 1.42×108粒,请编程计算宰相要求得到的麦粒体积为多少?

解题思路

使用for循环,将1一直乘2,每次都加到一个临时变量中,得出最终结果

#include <stdio.h>  
int main() {  
    unsigned long long nums = 0; // 存储麦粒  
    unsigned long long wheat = 1;  
    double grain = 1.42e8; // 体积为 1 立方米的麦粒数量  
    //循环进行计算  
    for (int i = 1; i <= 64; ++i) {  
        nums += wheat;  
        wheat *= 2;  
    }  
    double volume = (double )nums * grain; // 计算总体积  
    printf("麦粒的个数为:%llu\n",nums);  
    printf("麦粒体积为:%.2e 立方米\n",volume);  
    return 0;  
}
相关文章
|
10月前
|
存储 C语言
【C语言程序设计——函数】递归求斐波那契数列的前n项(头歌实践教学平台习题)【合集】
本关任务是编写递归函数求斐波那契数列的前n项。主要内容包括: 1. **递归的概念**:递归是一种函数直接或间接调用自身的编程技巧,通过“俄罗斯套娃”的方式解决问题。 2. **边界条件的确定**:边界条件是递归停止的条件,确保递归不会无限进行。例如,计算阶乘时,当n为0或1时返回1。 3. **循环控制与跳转语句**:介绍`for`、`while`循环及`break`、`continue`语句的使用方法。 编程要求是在右侧编辑器Begin--End之间补充代码,测试输入分别为3和5,预期输出为斐波那契数列的前几项。通关代码已给出,需确保正确实现递归逻辑并处理好边界条件,以避免栈溢出或结果
450 16
|
10月前
|
算法 C语言
【C语言程序设计——循环程序设计】求解最大公约数(头歌实践教学平台习题)【合集】
采用欧几里得算法(EuclideanAlgorithm)求解两个正整数的最大公约数。的最大公约数,然后检查最大公约数是否大于1。如果是,就返回1,表示。根据提示,在右侧编辑器Begin--End之间的区域内补充必要的代码。作为新的参数传递进去。这个递归过程会不断进行,直到。有除1以外的公约数;变为0,此时就找到了最大公约数。开始你的任务吧,祝你成功!是否为0,如果是,那么。就是最大公约数,直接返回。
247 18
|
10月前
|
Serverless C语言
【C语言程序设计——循环程序设计】利用循环求数值 x 的平方根(头歌实践教学平台习题)【合集】
根据提示在右侧编辑器Begin--End之间的区域内补充必要的代码,求解出数值x的平方根;运用迭代公式,编写一个循环程序,求解出数值x的平方根。注意:不能直接用平方根公式/函数求解本题!开始你的任务吧,祝你成功!​ 相关知识 求平方根的迭代公式 绝对值函数fabs() 循环语句 一、求平方根的迭代公式 1.原理 在C语言中,求一个数的平方根可以使用牛顿迭代法。对于方程(为要求平方根的数),设是的第n次近似值,牛顿迭代公式为。 其基本思想是从一个初始近似值开始,通过不断迭代这个公式,使得越来越接近。
211 18
|
10月前
|
C语言
【C语言程序设计——循环程序设计】统计海军鸣放礼炮声数量(头歌实践教学平台习题)【合集】
有A、B、C三艘军舰同时开始鸣放礼炮各21响。已知A舰每隔5秒1次,B舰每隔6秒放1次,C舰每隔7秒放1次。编程计算观众总共听到几次礼炮声。根据提示,在右侧编辑器Begin--End之间的区域内补充必要的代码。开始你的任务吧,祝你成功!
202 13
|
10月前
|
存储 安全 C语言
【C语言程序设计——选择结构程序设计】预测你的身高(头歌实践教学平台习题)【合集】
分支的语句,这可能不是预期的行为,这种现象被称为“case穿透”,在某些特定情况下可以利用这一特性来简化代码,但在大多数情况下,需要谨慎使用。编写一个程序,该程序需输入个人数据,进而预测其成年后的身高。根据提示,在右侧编辑器补充代码,计算并输出最终预测的身高。分支下的语句,提示用户输入无效。常量的值必须是唯一的,且在同一个。语句的作用至关重要,如果遗漏。开始你的任务吧,祝你成功!,程序将会继续执行下一个。常量都不匹配,就会执行。来确保程序的正确性。
307 10
|
10月前
|
小程序 C语言
【C语言程序设计——基础】顺序结构程序设计(头歌实践教学平台习题)【合集】
目录 任务描述 相关知识 编程要求 测试说明 我的通关代码: 测试结果: 任务描述 相关知识 编程编写一个程序,从键盘输入3个变量的值,例如a=5,b=6,c=7,然后将3个变量的值进行交换,使得a=6,b=7,c=5。面积=sqrt(s(s−a)(s−b)(s−c)),s=(a+b+c)/2。使用输入函数获取半径,格式指示符与数据类型一致,实验一下,不一致会如何。根据提示,在右侧编辑器补充代码,计算并输出圆的周长和面积。
225 10
|
10月前
|
存储 编译器 C语言
【C语言程序设计——函数】分数数列求和2(头歌实践教学平台习题)【合集】
函数首部:按照 C 语言语法,函数的定义首部表明这是一个自定义函数,函数名为fun,它接收一个整型参数n,用于指定要求阶乘的那个数,并且函数的返回值类型为float(在实际中如果阶乘结果数值较大,用float可能会有精度损失,也可以考虑使用double等更合适的数据类型,这里以float为例)。例如:// 函数体代码将放在这里函数体内部变量定义:在函数体中,首先需要定义一些变量来辅助完成阶乘的计算。比如需要定义一个变量(通常为float或double类型,这里假设用float。
278 3
|
10月前
|
存储 C语言
【C语言程序设计——循环程序设计】利用数列的累加和求 sinx(头歌实践教学平台习题)【合集】
项的累加和,一般会使用循环结构,在每次循环中计算出当前项的值(可能基于通项公式或者递推关系),然后累加到一个用于存储累加和的变量中。在C语言中推导数列中的某一项,通常需要依据数列给定的通项公式或者前后项之间的递推关系来实现。例如,对于一个简单的等差数列,其通项公式为。的级数,其每一项之间存在特定的递推关系(后项的分子是其前项的分子乘上。,计算sinx的值,直到最后一项的绝对值小于。为项数),就可以通过代码来计算出指定项的值。对于更复杂的数列,像题目中涉及的用于近似计算。开始你的任务吧,祝你成功!
244 6
|
10月前
|
存储 算法 安全
【C语言程序设计——函数】分数数列求和1(头歌实践教学平台习题)【合集】
if 语句是最基础的形式,当条件为真时执行其内部的语句块;switch 语句则适用于针对一个表达式的多个固定值进行判断,根据表达式的值与各个 case 后的常量值匹配情况,执行相应 case 分支下的语句,直到遇到 break 语句跳出 switch 结构,若没有匹配值则执行 default 分支(可选)。例如,在判断一个数是否大于 10 的场景中,条件表达式为 “num> 10”,这里的 “num” 是程序中的变量,通过比较其值与 10 的大小关系来确定条件的真假。常量的值必须是唯一的,且在同一个。
243 2
|
10月前
|
存储 编译器 C语言
【C语言程序设计——函数】回文数判定(头歌实践教学平台习题)【合集】
算术运算于 C 语言仿若精密 “齿轮组”,驱动着数值处理流程。编写函数求区间[100,500]中所有的回文数,要求每行打印10个数。根据提示在右侧编辑器Begin--End之间的区域内补充必要的代码。如果操作数是浮点数,在 C 语言中是不允许直接进行。的结果是 -1,因为 -7 除以 3 商为 -2,余数为 -1;注意:每一个数据输出格式为 printf("%4d", i);的结果是 1,因为 7 除以 -3 商为 -2,余数为 1。取余运算要求两个操作数必须是整数类型,包括。开始你的任务吧,祝你成功!
175 1