C语言系列 | 简单题练习

2023-05-16

第一题:简易计算器

思路:

定义变量后使用while无限循环执行,使用switch语句实现多分支选择。

源代码:

#include <stdio.h>
#include <stdlib.h>

int main()
{
    int i = 0;
    int j = 0;
    int sum = 0;
    int select = 0;
    while(1)
    {
        printf("==========================================\n");
        printf("计算器---请输入你需要的操作序号\n");
        printf("1. + \n");
        printf("2. - \n");
        printf("3. * \n");
        printf("4. / \n");
        printf("==========================================\n");
        scanf("%d", &select);    //输入运算符编号
        printf("请输入计算值");
        scanf("%d%d", &i, &j);    //输入运算数值
        switch (select)
        {
            case 1:
                printf("%d+%d=%d\n", i, j, sum=i+j);    //加
                break;
            case 2:
                printf("%d-%d=%d\n", i, j, sum=i-j);    //减
                break;
            case 3:
                printf("%d*%d=%d\n", i, j, sum=i*j);    //乘
                break;
            case 4:
                printf("%d/%d=%d\n", i, j, sum=i/j);    //除
                break;
            default:
                printf("输入有误请重新选择!");
                break;
        }
	}
    return 0;
}

运行结果:

请添加图片描述

第二题:从键盘输入一批学生的成绩,计算所有成绩大于60分的平均值和学生个数

思路:

定义变量并且从键盘接收数据,以0为整批成绩输入的结束条件,对每一个成绩进行判断,将所有大于60分的成绩求和。算出平均分并输出。

源代码:

3.
#include <stdio.h>
#include <stdlib.h>

int main()
{
    int num,count;
    double grade,sum;
    count=num=sum=0;
    printf("请输入成绩:");
    scanf("%lf",&grade);
    while(grade>0)
    {
        sum=sum+grade;
        num=num+1;
        while(grade>=60)
        {
            count=count+1;
            scanf("%lf",&grade);
        }
        scanf("%lf",&grade);
    }
    if(grade==0)
    {
        printf("average=0,count=0");
    }
    else
    {
        printf("平均分:%.2f \n60分以上的人数:%d\n",sum/num,count);
    }
    return 0;
}

运行结果:

请添加图片描述

第三题:找1000以内的所有完数

思路:

则需要定义一个变量 i来表示1~1000,然后定义一个变量 j 用来表示因子,定义一个变量 sum 来表示因子相加的和,for循环里对条件进行判断。

什么是完数:即完美数,一个数如果恰好等于除它本身外的因子之和。

什么是因子:如果整数A除B,得出结果是没有余数的整数,就称B是A的因子。eg: 8的因子有1,2,4和8。

源代码:

#include <stdio.h>
#include <stdlib.h>

int main()
{
    printf("1000以内的完数:\n");
	for(int i = 2;i <= 1000;i++)
	{
		int sum = 0;
		for(int j = 1;j <= i/2;j++)
		if(i%j == 0)
        {
            sum += j;
        }
		if(sum == i)
        {
            printf("%d\n",sum);
        }
	}
    return 0;
}

运行结果:

请添加图片描述

第四题:汉诺塔问题

思路:

定义汉诺塔函数,参数n是圆盘数,A、B、C是3根柱,判断圆盘数,如果等于1,递归条件,直接将A柱上的圆盘移动到C柱上,否者进行递归移动,递归将A柱最上方的n-1个盘子落在B柱,输出将A柱上的圆盘移动到C柱上,也就是将A柱的最小面盘子落在C柱,递归将B柱上的n-1个盘子,落在C柱。

A柱有n个圆盘时,移动次数为2n-1

源代码:

#include <stdio.h>
#include <stdlib.h>

void Hanio_Step(int n, char A, char B, char C)
{
    if (1 == n)
      printf("%c->%c\n", A, C);
    else
  {
    Hanio_Step(n-1, A, C, B);
    printf("%c->%c", A, C);
    Hanio_Step(n-1, B, A, C);
  }
}
int main()
{
  int n = 0;
  printf("请输入汉诺塔层数:");
  scanf("%d", &n);
  printf("执行步骤:\n");
  Hanio_Step(n, 'A', 'B', 'C');
  return 0;
}

运行结果:

请添加图片描述

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

C语言系列 | 简单题练习 的相关文章

  • HaneWIN (windows上的NFS服务器)使用说明

    使用说明 HaneWIN官网 xff1a https hanewin net nfs e htm比较好用的版本下载地址 xff1a https download csdn net download fword 85908535使用说明 xf
  • CAN总线简明易懂教程(一)

    先看看工作原理 当 CAN 总线上的一个节点 xff08 站 xff09 发送数据时 xff0c 它以报文的形式广播给网络中所有节点 xff0c 对每个节点来说 xff0c 无论数据是否是发给自己的 xff0c 都对其接收 每组报文开头的1
  • 北斗导航系统、GPS、GLONASS信号频率

    民用方面 xff1a GLONASS xff1a L1 61 1602 43 0 5625 k MHz 和L2 61 1246 43 0 4375 k MHz L1 L2 61 9 7 GPS L1 1575 42 43 10 MHz L2
  • centos下安装Java

    文章目录 1 解压2 配置环境变量 1 解压 首先将压缩包放到 usr local路径下 xff0c 解压缩 span class token builtin class name cd span usr local span class
  • 图像语义理解

    本文转载 from xff1a http blog csdn net haitun425 article details 8802182 1 目标的检测 分类和识别都为图像语义的理解服务 理解是硬道理 xff1b 2 不在于图像理解模型是否
  • 我的嵌入式5年 VS 我被国嵌的视频坑了的日子

    在嵌入式的行业工作四五年了 xff0c 想想从当初的身无分文和什么都不会 xff0c 到现在的还算衣食无忧 xff0c 住行别想 xff0c 技术也有点提升 xff0c 进入了手机行业 xff0c 其中的酸甜苦辣只有自己知道 xff0c 从
  • 我程序人生的启蒙书

    是这本书 xff0c 大一的我接触了c和c 43 43 xff0c 为数学专业的我打开了通往另一个世界的道路 xff0c 做一名优秀的程序员 是这本书 xff0c 大一的我开始废寝忘食的学习 xff0c 自习室里往往就放着这一本数 xff0
  • C++面试题(三)——STL相关各种问题

    C 43 43 面试题 STL相关各种问题 tanglu2004 http blog csdn net worldwindjp STL相关的各种问题 1 xff0c 用过那些容器 最常用的容器就是 xff1a vector list map
  • 基于 Docker 搭建开发环境

    基于 Node 官方镜像 https hub docker com node 获取镜像 在本地 Terminal 中执行 docker pull node 以获取 node 镜像 xff0c 可在 docker desktop 中查看 创建
  • tomcat 9 与mysql 5 的连接

    1 jdk的安装 配置JAVA HOME变量 xff0c 将该变量设置到path中 2 tomcat 下载 最新版本apache tomcat 9 0 0 M9配置根目录CATALINA HOME 61 D apache tomcat 9
  • 刷完 LeetCode 是什么水平?能拿到什么水平的 offer?

    链接 xff1a https www zhihu com question 32019460 编辑 xff1a 深度学习与计算机视觉 声明 xff1a 仅做学术分享 xff0c 侵删 刷题是我们一贯的学习方式 xff0c 但是学霸和学渣的区
  • 开心网争车位 发布

    本软件第一次使用C 编写 xff0c 是开心001争车位的辅助软件 可以帮助你管理多个账号一起停车挣钱 xff0c 使支持和热爱 开心网 的玩家更方便 xff0c 请勿与用商业 使用方法 xff1a 本软件需依靠 net3 5 xff0c
  • 博士“申请考核制”经验

    作者 xff1a 花花 链接 xff1a https zhuanlan zhihu com p 126168158 本文转载自知乎 xff0c 作者已授权 xff0c 未经许可请勿二次转载 本文是作者真实的经历 xff0c 给打算申请国内院
  • 研究生新生要怎么看论文?

    链接 xff1a https www zhihu com question 304334959 编辑 xff1a 深度学习与计算机视觉 声明 xff1a 仅做学术分享 xff0c 侵删 问题 xff1a 经常各种看不懂论文 而且感觉好多论文
  • 考博热会出现吗?

    链接 xff1a https www zhihu com question 408008199 编辑 xff1a 深度学习与计算机视觉 声明 xff1a 仅做学术分享 xff0c 侵删 考研热已经是不争的事实了 xff0c 每年考研人数都在
  • 基于python的MongoDB入门教程

    总览 MongoDB是数据科学家常用的一种非结构化数据库本文我们讨论如何使用Python xff08 和PyMongo库 xff09 来使用MongoDB数据库 本文我们使用Python实现对MongoDB数据库的所有基本操作 结构化数据库
  • 同组博士师兄的结果复现不出来,我应该怎么办?

    链接 xff1a https www zhihu com question 502804990 编辑 xff1a 深度学习与计算机视觉 声明 xff1a 仅做学术分享 xff0c 侵删 今年研二 xff0c 老师给了一个课题 xff0c 让
  • SOC电源标志 说明 VCC、VSS、VDD、VEE、VPP、Vddf

    VBAT VBAT是电源电压 xff0c VCC xff1a C 61 circuit 表示电路的意思 即接入电路的电压 VDD xff1a D 61 device 表示器件的意思 即器件内部的工作电压 VSS xff1a S 61 ser
  • “error LNK2019: 无法解析的外部符号”原因总结

    C 43 43 工程编译时出现如下链接错误提示 xff1a 原因一 xff1a 缺少实现 只是在 h里面声明了某个方法 xff0c 没有在cpp里面实现 xff1b 我出现过这个问题 xff1b 类方法的实现未加类标识 xff1a 如 xf
  • 不支持S/W HEVC(H265)解码的有效解决方案

    最近从WIN7更换为WIN10后 xff0c PotPlayer播放器加速出现不同步情况 xff0c 网上查找了很多办法 xff0c 最终奏效 失败方法一 xff1a FFmpeg64 dll 下载FFmpeg64 dll xff08 ht

随机推荐