【C语言必知必会 | 子系列第四篇】深入剖析选择结构(2)

news2025/1/13 2:43:14

引言

C语言是一门面向过程的、抽象化的通用程序设计语言,广泛应用于底层开发。它在编程语言中具有举足轻重的地位。
此文为【C语言必知必会】子系列第四篇,基于进行C语言选择结构的编程题专项练习,结合专题优质题目,带领读者从0开始,深度掌握知识点。

在这里插入图片描述

文章目录

    • 1️⃣ 前言
    • 2️⃣PTA专项练习
      • 1.两个数的简单计算器
      • 2.计算个人所得税
      • 3.计算天数
      • 4.求一元二次方程的根
      • 5.计算分段函数[2]
      • 6.比较大小
      • 7. 12-24小时制
      • 8.输出闰年
      • 9.新胖子公式
      • 10.成绩转换
    • 3️⃣ 总结


1️⃣ 前言

在【C语言你还没卷起来?】系列中,我们学习了顺序结构、选择结构、循环结构等,同时也通过专项练习进行了知识点的巩固和手敲代码的锻炼。

在子系列中,我们将基于PTA教学平台,向C语言学习者提供更优质的题目与更巧妙、精髓的解题思想与方法。

PTA是一个程序设计类实验辅助教学平台,由千名老师共同建设,里面包含了上万道高质量题目,用户量达百万。

在本讲中,将深入讲解选择结构的编程题,在思想上引领读者带领读者在理论结合实际的基础上更好地学习、吸收、掌握C语言。


2️⃣PTA专项练习

接下来,开始我们的选择结构专篇练习。

1.两个数的简单计算器

本题要求编写一个简单计算器程序,可根据输入的运算符,对2个整数进行加、减、乘、除或求余运算。题目保证输入和输出均不超过整型范围。

输入格式:
输入在一行中依次输入操作数1、运算符、操作数2,其间以1个空格分隔。操作数的数据类型为整型,且保证除法和求余的分母非零。

输出格式:
当运算符为+、-、*、/、%时,在一行输出相应的运算结果。若输入是非法符号(即除了加、减、乘、除和求余五种运算符以外的其他符号)则输出ERROR。

输入样例1:
-7 / 2

输出样例1:
-3

输入样例2:
3 & 6

输出样例2:
ERROR

解题思路:
使用switch-case语句即可

#include <stdio.h>
int main()
{
	int a,b;
	char c;
	scanf("%d %c %d",&a,&c,&b);
	switch(c)
	{
		case'+':
			printf("%d",a+b);
			break;
			
		case'-':
			printf("%d",a-b);
			break;
			
				case'*':
						printf("%d",a*b);
						break;
							case'/':
									printf("%d",a/b);
									break;	case'%':
												printf("%d",a%b);
												break;
		default:
			printf("ERROR");
			break;
		
	}
}

程序运行如下:

在这里插入图片描述


2.计算个人所得税

假设个人所得税为:税率×(工资−1600)。请编写程序计算应缴的所得税,其中税率定义为:
当工资不超过1600时,税率为0;
当工资在区间(1600, 2500]时,税率为5%;
当工资在区间(2500, 3500]时,税率为10%;
当工资在区间(3500, 4500]时,税率为15%;
当工资超过4500时,税率为20%。

输入格式:
输入在一行中给出非负工资。

输出格式:
在一行输出个人所得税,精确到小数点后2位。

输入样例1:
1600

输出样例1:
0.00

输入样例2:
1601

输出样例2:
0.05

输入样例3:
3000

输出样例3:
140.00

输入样例4:
4000

输出样例4:
360.00

输入样例5:
5000

输出样例5:
680.00

解题思路:选择结构采用if-else语句即可

代码如下:

#include<stdio.h>

int main()
{
    int a;
    double b;
    scanf("%d",&a);
    if(a<=1600) b=0;
    else if(a<=2500) b=(a-1600)*0.05;
    else if(a<=3500) b=(a-1600)*0.1;
    else if(a<=4500) b=(a-1600)*0.15;
    else b=(a-1600)*0.2;
    printf("%.2f",b);
	return 0;
}

程序运行结果:

在这里插入图片描述


3.计算天数

本题要求编写程序计算某年某月某日是该年中的第几天。

输入格式:
输入在一行中按照格式“yyyy/mm/dd”(即“年/月/日”)给出日期。注意:闰年的判别条件是该年年份能被4整除但不能被100整除、或者能被400整除。闰年的2月有29天。

输出格式:
在一行输出日期是该年中的第几天。

输入样例1:
2009/03/02

输出样例1:
61

输入样例2:
2000/03/02

输出样例2:
62

解题思路:先判断是否为闰年,进而确定二月的天数

#include<stdio.h>

int main()
{
    int a,b,c,d;
	scanf("%d/%d/%d",&a,&b,&c);
	if(a%4==0 && a%100!=0)  d=29;
	    else if(a%400==0) d=29;
	        else d=28;
	if(b==1) printf("%d",c);
	if(b==2) printf("%d",31+c);
	if(b==3) printf("%d",31+d+c);
	if(b==4) printf("%d",31*2+d+c);
	if(b==5) printf("%d",31*2+d+c+30);
	if(b==6) printf("%d",31*3+d+c+30);
	if(b==7) printf("%d",31*3+d+c+30*2);
	if(b==8) printf("%d",31*4+d+c+30*2);
	if(b==9) printf("%d",31*5+d+c+30*2);
	if(b==10) printf("%d",31*5+d+c+30*3);
	if(b==11) printf("%d",31*6+d+c+30*3);
	if(b==12) printf("%d",31*6+d+c+30*4);
	return 0;
}

程序运行结果:

在这里插入图片描述


4.求一元二次方程的根

本题目要求一元二次方程的根,结果保留2位小数。

输入格式:
输入在一行中给出3个浮点系数a、b、c,中间用空格分开。

输出格式:
根据系数情况,输出不同结果:

1)如果方程有两个不相等的实数根,则每行输出一个根,先大后小;

2)如果方程有两个不相等复数根,则每行按照格式“实部+虚部i”输出一个根,先输出虚部为正的,后输出虚部为负的;

3)如果方程只有一个根,则直接输出此根;

4)如果系数都为0,则输出"Zero Equation";

5)如果a和b为0,c不为0,则输出"Not An Equation"。

输入样例1:
2.1 8.9 3.5

输出样例1:
-0.44
-3.80

输入样例2:
1 2 3

输出样例2:
-1.00+1.41i
-1.00-1.41i

输入样例3:
0 2 4

输出样例3:
-2.00

输入样例4:
0 0 0

输出样例4:
Zero Equation

输入样例5:
0 0 1

输出样例5:
Not An Equation

解题思路:均注释于代码中,可逐个分析:

如果a和b都为0,进入第一个条件分支。如果c也为0,则输出"Zero Equation"表示零方程;如果c不为0,则输出"Not An Equation"表示非方程。
如果a为0,进入第二个条件分支。如果c不为0,则计算并输出根的值:c / (-b);如果c为0,则直接输出"0.00"。
如果判别式d大于0,进入第三个条件分支。计算并输出两个实根的值:(sqrt(d) - b) / (2 * a)和((-1) * sqrt(d) - b) / (2 * a)。
如果判别式d等于0,进入第四个条件分支。如果b不为0,则计算并输出根的值:b / (-2 * a);如果b为0,则直接输出"0.00"。
如果判别式d小于0,进入最后一个条件分支。如果b不为0,则计算并输出共轭复根的值:g + f i和g - f i;如果b为0,则实部为0,直接输出"0.00 + f i"和"0.00 - f i"。

代码如下:

#include<stdio.h>
#include<math.h>

int main()
{
    double a, b, c, d, x1, x2, e, f, g;
    
    // 读取输入的系数a、b和c
    scanf("%lf %lf %lf", &a, &b, &c);
    
    // 计算判别式d
    d = b * b - 4 * a * c;
    e = (-1) * d;
    
    if (a == 0 && b == 0)
    {
        // 当a和b均为0时
        if (c == 0)
            printf("Zero Equation"); // 输出"零方程"
        else
            printf("Not An Equation"); // 输出"非方程"
    }
    else
    {
        if (a == 0)
        {
            // 当a为0时
            if (c != 0)
                printf("%.2f", c / (-b)); // 输出"c/(-b)"
            else
                printf("0.00"); // 输出"0.00"
        }
        else if (d > 0)
        {    // a不为0时
            // 当判别式大于0时,方程有两个不同实根
            x1 = (sqrt(d) - b) / (2 * a);
            x2 = ((-1) * sqrt(d) - b) / (2 * a);
            
            // 输出两个实根
            printf("%.2f\n%.2f", x1, x2);
        }
        else if (d == 0)
        {
            // 当判别式等于0时,方程有两个相同实根
            if (b != 0)
                printf("%.2f", b / (-2 * a)); // 输出"b/(-2*a)"
            else
                printf("0.00"); // 输出"0.00"
        }
        else
        {
            // 当判别式小于0时,方程有共轭复根
            if (b != 0)
            {
                f = sqrt(e) / (2 * a);
                g = b / (-2 * a);
                
                // 输出共轭复根
                printf("%.2f+%.2fi\n%.2f-%.2fi", g, f, g, f);
            }
            else
            {
                // 如果b等于0,则实部为0
                printf("0.00+%.2fi\n0.00-%.2fi", f, f);
            }
        }
    }
    
    return 0;
}

程序运行结果:

在这里插入图片描述


5.计算分段函数[2]

本题目要求计算下列分段函数f(x)的值:

在这里插入图片描述

注:可在头文件中包含math.h,并调用sqrt函数求平方根,调用pow函数求幂。

输入格式:
输入在一行中给出实数x。

输出格式:
在一行中按“f(x) = result”的格式输出,其中x与result都保留两位小数。

输入样例1:
10

输出样例1:
f(10.00) = 3.16

输入样例2:
-0.5

输出样例2:
f(-0.50) = -2.75

按照题目要求即可,代码如下:

#include<stdio.h>
#include<math.h>
int main()
{
    double x,y;
    scanf("%lf",&x);
    if(x>=0) y=sqrt(x);
    else y=pow(x+1,2)+2*x+1/x;
    printf("f(%.2f) = %.2f",x,y);
	return 0;
}

程序运行结果:

在这里插入图片描述


6.比较大小

本题要求将输入的任意3个整数从小到大输出。

输入格式:
输入在一行中给出3个整数,其间以空格分隔。

输出格式:
在一行中将3个整数从小到大输出,其间以“->”相连。

输入样例:
4 2 8

输出样例:
2->4->8

简单的互换,代码如下:

#include<stdio.h>

int main()
{
    int a,b,c,d;
    scanf("%d %d %d",&a,&b,&c);
    if(a>b)
    {    //使a最小
    	d=a;
    	a=b;
    	b=d;
    }
    if(a>c)
    {   //再把a与c对比  使a最小
    	d=a;
    	a=c;
    	c=d;
    }
    if(b>c)
    {   //再把b与c对比
    	d=b;
    	b=c;
    	c=d;
    }
    printf("%d->%d->%d",a,b,c);
	return 0;
}

7. 12-24小时制

编写一个程序,要求用户输入24小时制的时间,然后显示12小时制的时间。

输入格式:
输入在一行中给出带有中间的:符号(半角的冒号)的24小时制的时间,如12:34表示12点34分。当小时或分钟数小于10时,均没有前导的零,如5:6表示5点零6分。

提示:在scanf的格式字符串中加入:,让scanf来处理这个冒号。

输出格式:
在一行中输出这个时间对应的12小时制的时间,数字部分格式与输入的相同,然后跟上空格,再跟上表示上午的字符串AM或表示下午的字符串PM。如5:6 PM表示下午5点零6分。注意,在英文的习惯中,中午12点被认为是下午,所以24小时制的12:00就是12小时制的12:0 PM;而0点被认为是第二天的时间,所以是0:0 AM。

输入样例:
21:11

输出样例:
9:11 PM

较为简单,根据提示即可,代码如下:

#include<stdio.h>

int main()
{
    int a,b;
    char c=':';
    scanf("%d%c%d",&a,&c,&b);
    if(a<12) printf("%d%c%d AM",a,c,b);
    else
	{
    	if(a==12) printf("%d%c%d PM",a,c,b);
		else printf("%d%c%d PM",a-12,c,b);
    }
    
	return 0;
}

程序运行结果:

在这里插入图片描述


8.输出闰年

输出21世纪中截止某个年份以来的所有闰年年份。注意:闰年的判别条件是该年年份能被4整除但不能被100整除、或者能被400整除。

输入格式:
输入在一行中给出21世纪的某个截止年份。

输出格式:
逐行输出满足条件的所有闰年年份,即每个年份占一行。输入若非21世纪的年份则输出"Invalid year!"。若不存在任何闰年,则输出“None”。

输入样例1:
2048

输出样例1:
2004
2008
2012
2016
2020
2024
2028
2032
2036
2040
2044
2048

输入样例2:
2000

输出样例2:
Invalid year!

较为简单,代码如下:

#include<stdio.h>

int main()
{
	int a,i;
	scanf("%d",&a);
	if(a<=2000) printf("Invalid year!");
	else if(a<2004) printf("None");
	else if(a<=2100)
	{
		for(i=2004;i<=a;i++)
		{
			if((i%4==0 && i%100!=0)||i%400==0) printf("%d\n",i);
		}
		
	}
	return 0;
}

程序运行结果:

在这里插入图片描述


9.新胖子公式

根据钱江晚报官方微博的报导,最新的肥胖计算方法为:体重(kg) / 身高(m) 的平方。如果超过 25,你就是胖子。于是本题就请你编写程序自动判断一个人到底算不算胖子。

输入格式:
输入在一行中给出两个正数,依次为一个人的体重(以 kg 为单位)和身高(以 m 为单位),其间以空格分隔。其中体重不超过 1000 kg,身高不超过 3.0 m。

输出格式:
首先输出将该人的体重和身高代入肥胖公式的计算结果,保留小数点后 1 位。如果这个数值大于 25,就在第二行输出 PANG,否则输出 Hai Xing。

输入样例 1:
100.1 1.74

输出样例 1:
33.1
PANG

输入样例 2:
65 1.70

输出样例 2:
22.5
Hai Xing

较为简单,代码如下:

#include<stdio.h>

int main()
{
	double a,b,c;
	scanf("%lf %lf",&a,&b);
	c=a/(b*b);
	if(c>25) printf("%.1f\nPANG",c);
	else printf("%.1f\nHai Xing",c);
	return 0;
}

程序运行结果:

在这里插入图片描述


10.成绩转换

本题要求编写程序将一个百分制成绩转换为五分制成绩。转换规则:

大于等于90分为A;
小于90且大于等于80为B;
小于80且大于等于70为C;
小于70且大于等于60为D;
小于60为E。

输入格式:
输入在一行中给出一个整数的百分制成绩。

输出格式:
在一行中输出对应的五分制成绩。

输入样例:
90

输出样例:
A

解题思路:使用switch语句即可,也可使用if-else语句

代码如下:

#include<stdio.h>

int main()
{
	int a,b;
	scanf("%d",&a);
	b=a/10;
	switch(b)
	{
	    case 10:
		case 9:
		    printf("A");
		    break;
		case 8:
		    printf("B");
		    break;
		case 7:
			printf("C");
			break;
		case 6:
			printf("D");
			break;
		default:
			printf("E");
			break;
	}
	return 0;
}

程序运行结果:

在这里插入图片描述


3️⃣ 总结

此文为 【C语言必知必会】子系列第四篇 ,通过以题代练的形式带领读者掌握C语言的选择结构,带领读者从0开始,深度掌握知识点。

以题代练对于C语言的学习是十分重要的,专栏将持续提供优质C语言编程题与理论课的学习,带领读者全方位掌握C语言,读者可订阅专栏持续跟进。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1115571.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

VMware Workstation里面安装ubuntu20.04的流程

文章目录 前言一、获取 desktop ubuntu20.04 安装镜像二、VMware Workstation下安装ubuntu20.041. VMware Workstation 创建一个新的虚拟机2. ubuntu20.04的安装过程3. 登录ubuntu20.044. 移除 ubuntu20.04 安装镜像总结参考资料前言 本文主要介绍如何在PC上的虚拟机(VMware W…

ESP32C3 LuatOS TM1650①驱动测试

合宙TM1650驱动资料 TM1650.lua源码 引脚连接 TM1650ESP32C3SCLGPIO5SDAGPIO4 下载TM1650.lua源码&#xff0c;并以文件形式保存在项目文件夹中 驱动测试源码 --注意:因使用了sys.wait()所有api需要在协程中使用 -- 用法实例 PROJECT "ESP32C3_TM1650" VERSION …

批量xls转换为xlsx

import win32com.client as win32 import os# 另存为xlsx的文件路径 xlsx_file r"F:\志丹\1020Excel汇总\成果表备份\xlsx" xls_file r"F:\志丹\1020Excel汇总\成果表备份" for file in os.scandir(xls_file):suffix file.name.split(".")[-1…

AQS源码与实现原理

前言 前段时间在看ReentrantLocak及其依赖的基础模板类AbstractQueuedSynchronizer的源码&#xff0c;自己看源码同时在网上找文章&#xff0c;然而对源码中的一些细节问题还是不太理解&#xff0c;比如为什么阻塞的线程因中断被唤醒后需要重新中断&#xff0c;为什么被Condit…

uipath 调用 webapi 接口使用示例

环境依赖下载 提示&#xff1a;需要先按照webapi包依赖 文章目录 环境依赖下载一、webapi是什么&#xff1f;二、使用步骤1.导入cURL http 请求 一、webapi是什么&#xff1f; UiPath WebAPI包是一个用于实现与Web服务进行交互的UiPath活动库。它基于.NET Framework 4.5及以上…

ddns-go配合aliyun域名解析通过ipv6实现共享桌面

ddns-go配合aliyun域名解析通过ipv6实现共享桌面 前提&#xff1a; 必须拥有ipv6公网IP&#xff0c;测试IPv6 测试 (testipv6.cn) 如果是光猫拨号一点要选择ipv4和ipv6&#xff0c;同时要看光猫是否支持ipv6转发&#xff0c;如果不支持转发也不行&#xff0c;光猫不支持ipv6…

一阶系统阶跃响应实现规划方波目标值

一阶系统单位阶跃响应 一阶系统传递函数&#xff0c;实质是一阶惯性环节&#xff0c;T为一阶系统时间常数。 输入信号为单位阶跃函数&#xff0c;数学表达式 单位阶跃函数拉氏变换 输出一阶系统单位阶跃响应 拉普拉斯反变换 使用前向差分法对一阶系统离散化 将z变换写成差分方…

分类网络-类别不均衡问题之FocalLoss

有训练和测代码如下&#xff1a;(完整代码来自CNN从搭建到部署实战) train.py import torch import torchvision import time import argparse import importlib from loss import FocalLossdef parse_args():parser argparse.ArgumentParser(training)parser.add_argument(-…

Monocle 3 | 太牛了!单细胞必学R包!~(一)(预处理与降维聚类)

1写在前面 忙碌的一周结束了&#xff0c;终于迎来周末了。&#x1fae0; 这周的手术真的是做到崩溃&#xff0c;2天的手术都过点了。&#x1fae0; 真的希望有时间静下来思考一下。&#x1fae0; 最近的教程可能会陆续写一下Monocle 3&#xff0c;炙手可热啊&#xff0c;欢迎大…

【七:docken+jenkens部署】

一&#xff1a;腾讯云轻量服务器docker部署Jenkins https://blog.csdn.net/qq_35402057/article/details/123589493 步骤1&#xff1a;查询jenkins版本&#xff1a;docker search jenkins步骤2&#xff1a;拉取jenkins镜像 docker pull jenkins/jenkins:lts步骤3&#xff1a;…

设计模式:外观模式(C#、JAVA、JavaScript、C++、Python、Go、PHP)

大家好&#xff01;本节主要介绍设计模式中的外观模式。 简介&#xff1a; 外观模式&#xff0c;它是一种设计模式&#xff0c;它为子系统中的一组接口提供一个统一的、简单的接口。这种模式主张按照描述和判断资料来评价课程&#xff0c;关键活动是在课程实施的全过程中进行…

【C语言必知必会 | 第八篇】一文带你精通循环结构

引言 C语言是一门面向过程的、抽象化的通用程序设计语言&#xff0c;广泛应用于底层开发。它在编程语言中具有举足轻重的地位。 此文为【C语言必知必会】系列第八篇&#xff0c;进行C语言循环结构的专项练习&#xff0c;结合专题优质题目&#xff0c;带领读者从0开始&#xff0…

丰富功能带来新奇体验,乐划锁屏持续引领行业潮流

在日常使用手机的过程中,为了省电或在口袋里误触,不少用户都会对手机进行锁屏,有这么一款锁屏软件,不仅能够解决以上功能性问题,还有不少其他新奇的功能,那就是乐划锁屏。 现在“手机不离手”、每天翻看手机上百遍的年轻人,最喜欢关注什么样的内容呢?乐划锁屏以图片和视频为主…

RabbitMQ官方案例学习记录

官方文档&#xff1a;RabbitMQ教程 — RabbitMQ (rabbitmq.com) 一、安装RabbitMQ服务 直接使用docker在服务器上安装 docker run -it -d --name rabbitmq -p 5672:5672 -p 15672:15672 rabbitmq:3.12-management 安装完成后&#xff0c;访问15672端口&#xff0c;默认用户…

实时数据更新与Apollo:探索GraphQL订阅

前言 「作者主页」&#xff1a;雪碧有白泡泡 「个人网站」&#xff1a;雪碧的个人网站 「推荐专栏」&#xff1a; ★java一站式服务 ★ ★ React从入门到精通★ ★前端炫酷代码分享 ★ ★ 从0到英雄&#xff0c;vue成神之路★ ★ uniapp-从构建到提升★ ★ 从0到英雄&#xff…

FIFO设计16*8,verilog,源码和视频

名称&#xff1a;FIFO设计16*8&#xff0c;数据显示在数码管 软件&#xff1a;Quartus 语言&#xff1a;Verilog 代码功能&#xff1a; 使用verilog语言设计一个16*8的FIFO&#xff0c;深度16&#xff0c;宽度为8。可对FIFO进行写和读&#xff0c;并将FIFO读出的数据显示到…

【微服务保护】初识 Sentinel —— 探索微服务雪崩问题的解决方案,Sentinel 的安装部署以及将 Sentinel 集成到微服务项目

文章目录 前言一、雪崩问题及其解决方案1.1 什么是雪崩问题1.2 雪崩问题的原因1.3 解决雪崩问题的方法1.4 总结 二、初识 Sentinel 框架2.1 什么是 Sentinel2.2 Sentinel 和 Hystrix 的对比 三、Sentinel 的安装部署四、集成 Sentinel 到微服务 前言 微服务架构在现代软件开发…

Rust通用编程概念

文章目录 变量与可变性数据类型标量类型整数类型浮点类型布尔类型字符类型 复合类型元组数组 函数注释控制流if表达式循环 变量与可变性 变量与可变性 在Rust中&#xff0c;声明变量使用let关键字&#xff0c;并且默认情况下&#xff0c;声明的变量是不可变的&#xff0c;要使变…

C语言实现用递归法将一个整数 n 转换成字符串。例如,输入 483,应输出字符串“483“。n 的位数不确定,可以是任意位数的整数

完整代码&#xff1a; /*用递归法将一个整数 n 转换成字符串。例如&#xff0c;输入 483&#xff0c;应输出字符串"483"。n 的 位数不确定&#xff0c;可以是任意位数的整数。*/ #include<stdio.h> //long long int让n的取值范围更广 void func(long long int…

手搭手zabbix5.0监控redis7

Centos7安装配置Redis7 安装redis #安装gcc yum -y install gcc gcc-c #安装net-tools yum -y install net-tools #官网https://redis.io/ cd /opt/ wget http://download.redis.io/releases/redis-7.0.4.tar.gz 解压至/opt/目录下 tar -zxvf redis-7.0.4.tar.gz -C /opt/ #…