《C++语言程序设计(第5版)》(清华大学出版社,郑莉 董渊编著)习题——第2章 C++语言简单程序设计

2-15 编写一个程序,运行时提示输入一个数字,再把这个数字显示出来。

#include <iostream>using namespace std;int main() {// 提示用户输入数字cout << "请输入一个数字: ";// 用于存储用户输入的数字的变量double number;// 从标准输入读取用户输入的数字cin >> number;// 显示用户输入的数字cout << "您输入的数字是: " << number << endl;return 0;
}

 

2-16 C++语言有哪几种数据类型?简述其值域。编程显示你使用的计算机中的各种数据类型的字节数。

#include <iostream>using namespace std;int main() {cout << "整型的大小: " << sizeof(int) << " 字节\n";cout << "长整型的大小: " << sizeof(long) << " 字节\n";cout << "短整型的大小: " << sizeof(short) << " 字节\n";cout << "字符型的大小: " << sizeof(char) << " 字节\n";cout << "单精度浮点型的大小: " << sizeof(float) << " 字节\n";cout << "双精度浮点型的大小: " << sizeof(double) << " 字节\n";cout << "布尔型的大小: " << sizeof(bool) << " 字节\n";// 根据需要添加更多的数据类型return 0;
}

2-17 输出ASCⅡ码为32~127的字符。

#include <iostream>using namespace std;int main() {// 输出ASCII码为32~127的字符for (int i = 32; i <= 127; ++i) {cout << char(i) << " ";}cout << endl;return 0;
}

2-25 编写一个完整的程序,实现功能:向用户提问“现在正在下雨吗?”,提示用户输入Y或N。若输入为Y,显示“现在正在下雨。”;若输入为N,显示“现在没有下雨。”;否则继续提问“现在正在下雨吗?”。

#include <iostream>
#include <string>int main() {std::string userInput;do {// 提问用户是否正在下雨std::cout << "现在正在下雨吗?(输入Y或N): ";std::cin >> userInput;// 处理用户输入if (userInput == "Y" || userInput == "y") {std::cout << "现在正在下雨。\n";} else if (userInput == "N" || userInput == "n") {std::cout << "现在没有下雨。\n";} else {std::cout << "无效的输入,请输入Y或N。\n";}} while (userInput != "Y" && userInput != "y" && userInput != "N" && userInput != "n");return 0;
}

2-26 编写一个完整的程序,运行时向用户提问“你考试考了多少分?(0~100)”,接收输入后判断其等级显示出来。规则如下:
优90≤分数≤100

良80≤分数<90

中60≤分数<80

差0≤分数<60

#include <iostream>int main() {// 提示用户输入分数std::cout << "你考试考了多少分?(0~100): ";// 接收用户输入int score;std::cin >> score;// 判断等级并显示结果if (score >= 90 && score <= 100) {std::cout << "优\n";} else if (score >= 80 && score < 90) {std::cout << "良\n";} else if (score >= 60 && score < 80) {std::cout << "中\n";} else if (score >= 0 && score < 60) {std::cout << "差\n";} else {std::cout << "输入无效,分数应在0~100之间。\n";}return 0;
}

2-27 实现一个简单的菜单程序,运行时显示“Menu:A(dd) D(elete) S(ort) Q(uit),Selet one:“提醒用户输入,A表示增加,D表示删除,S表示排序,Q表示退出,输入为A、D、S时分别提示“数据已经增加、删除、排序。”输入为Q时程序结束。

(1)要求使用if…else语句进行判断,用break、continue控制程序流程。

(2)要求使用switch语句。

//使用if...else#include <iostream>
#include <vector>
#include <algorithm>using namespace std;int main() {vector<string> data;  // 用于存储数据的向量while (true) {cout << "菜单:A(增加) D(删除) S(排序) Q(退出)\n";char choice;cout << "请选择:";cin >> choice;if (choice == 'A') {// 增加数据string newData;cout << "输入要增加的数据:";cin >> newData;data.push_back(newData);cout << "数据已经增加。\n";} else if (choice == 'D') {// 删除数据if (data.empty()) {cout << "没有数据可以删除。\n";} else {cout << "原始数据:";for (size_t i = 0; i < data.size(); ++i) {cout << data[i] << " ";}cout << "\n输入要删除的数据:";string itemToDelete;cin >> itemToDelete;vector<string>::iterator it = find(data.begin(), data.end(), itemToDelete);if (it != data.end()) {data.erase(it);cout << "数据已经删除。\n";} else {cout << "未找到数据。\n";}}} else if (choice == 'S') {// 排序数据if (data.empty()) {cout << "没有数据可以排序。\n";} else {sort(data.begin(), data.end());cout << "数据已经排序。\n";}} else if (choice == 'Q') {// 退出程序cout << "程序正在退出。\n";break;} else {// 处理无效输入cout << "无效的选择。请键入 A、D、S 或 Q。\n";continue;}// 显示当前数据cout << "当前数据:";for (size_t i = 0; i < data.size(); ++i) {cout << data[i] << " ";}cout << "\n\n";}return 0;
}

// 使用switch语句#include <iostream>
#include <vector>
#include <algorithm>using namespace std;int main() {vector<string> data;  // 用于存储数据的向量char choice;while (true) {cout << "菜单:A(增加) D(删除) S(排序) Q(退出)\n";cout << "请选择:";cin >> choice;switch (choice) {case 'A':case 'a': {// 增加数据string newData;cout << "请输入要增加的数据:";cin >> newData;data.push_back(newData);cout << "数据已经增加。\n";break;}case 'D':case 'd': {// 删除数据if (data.empty()) {cout << "没有数据可以删除。\n";} else {cout << "当前数据:";for (size_t i = 0; i < data.size(); ++i) {cout << data[i] << " ";}cout << "\n请输入要删除的数据:";string itemToDelete;cin >> itemToDelete;size_t indexToDelete = 0;bool found = false;for (size_t i = 0; i < data.size(); ++i) {if (data[i] == itemToDelete) {indexToDelete = i;found = true;break;}}if (found) {data.erase(data.begin() + indexToDelete);cout << "数据已经删除。\n";} else {cout << "未找到数据。\n";}}break;}case 'S':case 's': {// 排序数据if (data.empty()) {cout << "没有数据可以排序。\n";} else {sort(data.begin(), data.end());cout << "数据已经排序。\n";}break;}case 'Q':case 'q':// 退出程序cout << "程序正在退出。\n";return 0;default:// 处理无效输入cout << "无效的选择,请输入A、D、S或Q。\n";}// 显示当前数据cout << "当前数据:";for (size_t i = 0; i < data.size(); ++i) {cout << data[i] << " ";}cout << "\n\n";}return 0;
}

2-28 用穷举法找出1~100的质数并显示出来。分别使用while、do-while、for循环语句实现。

// 使用while循环#include <iostream>using namespace std;int main() {int number = 2;cout << "1~100之间的质数有:";while (number <= 100) {int divisor = 2;bool isPrime = true;while (divisor <= number / 2) {if (number % divisor == 0) {isPrime = false;break;}divisor++;}if (isPrime) {cout << number << " ";}number++;}cout << endl;return 0;
}
//使用do...while语句#include <iostream>using namespace std;int main() {int number = 2;cout << "1~100之间的质数有:";do {int divisor = 2;bool isPrime = true;do {if (number % divisor == 0) {isPrime = false;break;}divisor++;} while (divisor <= number / 2);if (isPrime) {cout << number << " ";}number++;} while (number <= 100);cout << endl;return 0;
}
//使用for循环语句#include <iostream>using namespace std;int main() {cout << "1~100之间的质数有:";for (int number = 2; number <= 100; ++number) {bool isPrime = true;for (int divisor = 2; divisor <= number / 2; ++divisor) {if (number % divisor == 0) {isPrime = false;break;}}if (isPrime) {cout << number << " ";}}cout << endl;return 0;
}

2-30 声明一个表示时间的结构体,可以精确表示年、月、日、小时、分、秒;提示用户输入年、月、日、小时、分、秒的值,然后完整地显示出来

#include <iostream>using namespace std;// 定义表示时间的结构体
struct Time {int year;int month;int day;int hour;int minute;int second;
};int main() {// 创建时间结构体变量Time time;// 提示用户输入时间信息cout << "请输入年份: ";cin >> time.year;cout << "请输入月份: ";cin >> time.month;cout << "请输入日期: ";cin >> time.day;cout << "请输入小时: ";cin >> time.hour;cout << "请输入分钟: ";cin >> time.minute;cout << "请输入秒数: ";cin >> time.second;// 显示完整的时间信息cout << "输入的时间为:" << time.year << "年" << time.month << "月" << time.day << "日 "<< time.hour << "时" << time.minute << "分" << time.second << "秒" << endl;return 0;
}

2-31 在程序中定义一个整型变量,赋以1~100的值,要求用户猜这个数,比较两个数的大小,把结果提示给用户,直到猜对为止。分别使用while、do...while语句实现循环。

//使用while循环#include <iostream>using namespace std;int main() {int targetNumber = 42; // 要猜的数字int userGuess;cout << "猜一猜1~100之间的数字: ";// 使用while循环while (true) {cin >> userGuess;if (userGuess == targetNumber) {cout << "恭喜你,猜对了!" << endl;break; // 结束循环} else if (userGuess < targetNumber) {cout << "猜的数字太小了,请再试一次: ";} else {cout << "猜的数字太大了,请再试一次: ";}}return 0;
}
// 使用do...while语句#include <iostream>using namespace std;int main() {int targetNumber = 42; // 要猜的数字int userGuess;cout << "猜一猜1~100之间的数字: ";// 使用do...while循环do {cin >> userGuess;if (userGuess == targetNumber) {cout << "恭喜你,猜对了!" << endl;} else if (userGuess < targetNumber) {cout << "猜的数字太小了,请再试一次: ";} else {cout << "猜的数字太大了,请再试一次: ";}} while (userGuess != targetNumber);return 0;
}

2-32 口袋中有红、黄、蓝、白、黑5种颜色的球若干个。每次从口袋种取出3个不同颜色的球,问有多少种取法?

#include <iostream>
#include <string>using namespace std;int main() {const int totalColors = 5; // 总颜色数const int ballsPerDraw = 3; // 每次取出的球数string colors[] = {"红", "黄", "蓝", "白", "黑"};int combinationCount = 0;// 循环遍历所有可能的排列for (int color1 = 0; color1 < totalColors; ++color1) {for (int color2 = 0; color2 < totalColors; ++color2) {for (int color3 = 0; color3 < totalColors; ++color3) {if (color1 != color2 && color1 != color3 && color2 != color3) {// 输出当前排列和编号cout  << combinationCount + 1 << " ";cout << colors[color1] << " " << colors[color2] << " " << colors[color3] << endl;combinationCount++;}}}}// 输出总的排列数cout << "总共有 " << combinationCount << " 种取法。" << endl;return 0;
}

2-33 输出九九乘法表

#include<bits/stdc++.h>
using namespace std;
//打印九九乘法表
int main(){
int i=0;
int j=0;
for(i=1;i<=9;i++){for(j=1;j<=i;j++){cout<<j<<"*"<<i<<"="<<i*j<<" ";}cout<<endl;
}
return 0;
}

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

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

相关文章

FineBI实战(2):案例架构说明及数据准备

1 系统架构 基于MySQL搭建数据仓库基于Kettle进行数据处理帆软FineBI基于MySQL搭建的数据仓库进行数据分析 2 数据流程图 通过Kettle将MySQL业务系统数据库中&#xff0c;将数据抽取出来&#xff0c;然后装载到MySQL数据仓库中。编写SQL脚本&#xff0c;对MySQL数据仓库中的数…

LeetCode 2807. 在链表中插入最大公约数【链表,迭代,递归】1279

本文属于「征服LeetCode」系列文章之一&#xff0c;这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁&#xff0c;本系列将至少持续到刷完所有无锁题之日为止&#xff1b;由于LeetCode还在不断地创建新题&#xff0c;本系列的终止日期可能是永远。在这一系列刷题文章…

数据结构和算法-交换排序中的快速排序(演示过程 算法实现 算法效率 稳定性)

文章目录 总览快速排序&#xff08;超级重要&#xff09;啥是快速排序演示过程算法实现第一次quicksort函数第一次partion函数到第一次quicksort的第一个quicksort到第二次quicksort的第一个quicksort到第二次quicksort的第二个quicksort到第一次quicksort的第二个quicksort到第…

Java反射和动态代理

文章目录 1、反射1.1 反射的概述1.2 反射作用1.3 获取字节码文件对象的方式1.4 字节码文件和字节码文件对象1.5 获取构造方法1.6 获取构造方法并创建对象1.7 获取成员变量并获取值和修改值1.8 获取成员方法1.9 获取成员方法并运行1.10 反射练习1.10.1 泛型擦除1.10.2 修改字符串…

uniapp 创建组件组件

组件&#xff1a;用于将某个功能的 HTML、CSS、JS 封装到一个文件中&#xff0c;提高代码的复用性和可维护性。 创建组件 一、在根目录中创建 components 文件夹&#xff0c;右键点击新建组件。 二、输入组件名称、选择默认模板、点击创建组件。 三、在组件中正常编写内容即可…

动态编译 - Dynamically Compile and Load External Java Classes

文章目录 概述Code 概述 动态编译和加载外部Java类的核心流程可以概括为以下几个步骤&#xff1a; 读取源代码: 首先&#xff0c;需要获取到外部的Java源代码。这通常是通过读取文件、网络资源或者数据库中的源代码字符串来实现的。编译源代码: 接下来&#xff0c;需要使用Ja…

计算机网络(8):因特网上的音频/视频服务

概述 计算机网络最初是为传送数据设计的。因特网 IP 层提供的 “尽最大努力交付” 服务以及每一个分组独立交付的策略&#xff0c;对传送数据信息十分合适。因特网使用的 TCP 协议可以很好地解决P层不能提供可靠交付这一问题。 音频/视频常称为多媒体信息 多媒体信息&#xff…

【BIAI】lecture 3 - GD BP CNN Hands-on

GD & BP & CNN & Hands-on 专业术语 gradient descent (GD) 梯度下降 back propagation (BP) 向传播 Convolutional Neural Network (CNN) 卷积神经网络 forward propagation 前向传播 biologically symmetry 生物对称性 synaptic 突触 axon 轴突 课程大纲 The go…

BUUCTF crypto做题记录(6)新手向

一、Unencode 得到的密文&#xff1a;89FQA9WMD<V1A<V1S83DY.#<W3$Q,2TM] 看题目名字&#xff0c;我们可以知道这是一个解码的题目&#xff0c;但是unencode 好像是不可解码的意思&#xff0c;我们可以对照着解码方式看一下哪个更适合&#xff0c;可以进行尝试一下C…

RocketMQ 投递消息方式以及消息体结构分析:Message、MessageQueueSelector

&#x1f52d; 嗨&#xff0c;您好 &#x1f44b; 我是 vnjohn&#xff0c;在互联网企业担任 Java 开发&#xff0c;CSDN 优质创作者 &#x1f4d6; 推荐专栏&#xff1a;Spring、MySQL、Nacos、Java&#xff0c;后续其他专栏会持续优化更新迭代 &#x1f332;文章所在专栏&…

腾讯云取消免费10G CDN流量包:免费CDN时代结束

关注卢松松&#xff0c;会经常给你分享一些我的经验和观点。 免费送了7-8年的腾讯云10G免费流量包&#xff0c;从2024年开始&#xff0c;停止赠送了!自此&#xff0c;国内绝大多数互联网大厂的CDN都开收费了! 大概从2016年开始&#xff0c;腾讯云为了抢夺CDN客户&#xff0…

基于Spring-boot-websocket的聊天应用开发总结

目录 1.概述 1.1 Websocket 1.2 STOMP 1.3 源码 2.Springboot集成WS 2.1 添加依赖 2.2 ws配置 2.2.1 WebSocketMessageBrokerConfigurer 2.2.2 ChatController 2.2.3 ChatInRoomController 2.2.4 ChatToUserController 2.3 前端聊天配置 2.3.1 index.html和main.j…

mnn-llm: 大语言模型端侧CPU推理优化

在大语言模型(LLM)端侧部署上&#xff0c;基于 MNN 实现的 mnn-llm 项目已经展现出业界领先的性能&#xff0c;特别是在 ARM 架构的 CPU 上。目前利用 mnn-llm 的推理能力&#xff0c;qwen-1.8b在mnn-llm的驱动下能够在移动端达到端侧实时会话的能力&#xff0c;能够在较低内存…

MySQL之视图外连接、内连接和子查询的使用

一、视图 1.1 含义 虚拟表&#xff0c;和普通表一样使用 1.2 操作 创建视图 create view 视图名 as 修改视图 方式一&#xff1a; create or replace view 视图名 as 【查看视图相关字段】 方式二&#xff1a; alter view 视图名 as 【查看的SQL语句】 查看视图 方式一&…

Nginx快速入门:Nginx实现高可用|结合keepalived实现主备节点(九)

0. 引言 在生产中我们要尽可能避免单点故障&#xff0c;nginx也不例外&#xff0c;因此搭建主备节点必不可少&#xff0c;今天我们来学习下如何利用keepalived实现主备 1. keepalived简介 keepalived 是一个LINUX系统中开源的负载均衡和故障转移软件&#xff0c;它主要用于高…

2024年阿里云、腾讯云、华为云、LightNode、硅云服务器如何选?怎么买最划算?[最新价格表]

很多小伙伴都有一颗上云的心&#xff0c;包括我自己 有事没事的折腾一下自己的小破站&#xff0c;也挺有意思的&#xff01; 那么&#xff0c;云服务器哪家好&#xff1f;优惠力度哪家大&#xff1f;活动入口哪里进&#xff1f;云服务器如何配置&#xff1f;如何选型&#xf…

K8S集群部署解决工作节点couldn‘t get current server API group list问题

最近在自己电脑上装了VMWare Player&#xff0c;在上面装了两个Ubuntu虚拟机&#xff0c;为了方便学习云原生技术&#xff0c;决定在上面装一个2个节点&#xff08;一个控制面&#xff0c;一个工作节点&#xff09;的K8S集群。 参考这篇文章&#xff1a; Ubuntu 22.04 搭建K8…

kubectl的插件安装工具krew

最近得知一个kubectl插件安装工具&#xff0c;叫做krew。 官网地址是&#xff1a;Krew – kubectl plugin manager 安装krew 按照官网的做法&#xff0c;一直安装失败&#xff0c;于是拆解步骤&#xff0c;一步一步下载离线安装。 1、下载krew.yaml 地址&#xff1a;https:…

Proteus 各版本安装指南

Proteus下载链接 https://pan.baidu.com/s/1vHgg8jK9KSHdxSU9SDy4vQ?pwd0531 1.鼠标右击【Proteus8.15(64bit&#xff09;】压缩包&#xff08;win11及以上系统需先点击“显示更多选项”&#xff09;【解压到Proteus8.15(64bit&#xff09; 】。 2.打开解压后的文件夹&#…

适用于生物行业的生信云平台

随着基因检测技术的不断发展&#xff0c;生物信息云平台在基因检测行业的应用越来越广泛。生物信息云平台是一种基于云计算的技术&#xff0c;可以将基因检测数据存储在云端&#xff0c;并通过数据分析、挖掘等技术手段&#xff0c;对基因数据进行处理、分析和解读。 这种技术的…