当前位置: 首页 > news >正文

《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;
}

相关文章:

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

2-15 编写一个程序&#xff0c;运行时提示输入一个数字&#xff0c;再把这个数字显示出来。 #include <iostream>using namespace std;int main() {// 提示用户输入数字cout << "请输入一个数字: ";// 用于存储用户输入的数字的变量double number;// 从…...

2023年生成式AI全球使用报告

生成式人工智能工具正在迅速改变多个领域&#xff0c;从营销和新闻到教育和艺术。 这些工具使用算法从大量培训材料中获取新的文本、音频或图像。虽然 ChatGPT 和 Midjourney 之类的工具可以用来实现超出人类能力或想象力的艺术效果&#xff0c;但目前它们最常用于比人类更轻松…...

安全防御之漏洞扫描技术

每年都有数以千计的网络安全漏洞被发现和公布&#xff0c;加上攻击者手段的不断变化&#xff0c;网络安全状况也在随着安全漏洞的增加变得日益严峻。寻根溯源&#xff0c;绝大多数用户缺乏一套完整、有效的漏洞管理工作流程&#xff0c;未能落实定期评估与漏洞修补工作。只有比…...

SPON世邦 IP网络对讲广播系统 多处文件上传漏洞复现

0x01 产品简介 SPON世邦IP网络对讲广播系统是一种先进的通信解决方案,旨在提供高效的网络对讲和广播功能。 0x02 漏洞概述 SPON世邦IP网络对讲广播系统 addscenedata.php、uploadjson.php、my_parser.php等接口处存在任意文件上传漏洞,未经身份验证的攻击者可利用此漏洞上…...

Python综合数据分析_RFM用户分层模型

文章目录 1.数据加载2.查看数据情况3.数据合并及填充4.查看特征字段之间相关性5.聚合操作6.时间维度上看销售额7.计算用户RFM8.数据保存存储(1).to_csv(1).to_pickle 1.数据加载 import pandas as pd dataset pd.read_csv(SupplyChain.csv, encodingunicode_escape) dataset2…...

【C++进阶04】STL中map、set、multimap、multiset的介绍及使用

一、关联式容器 vector/list/deque… 这些容器统称为序列式容器 因为其底层为线性序列的数据结构 里面存储的是元素本身 map/set… 这些容器统称为关联式容器 关联式容器也是用来存储数据的 与序列式容器不同的是 其里面存储的是<key, value>结构的键值对 在数据检索时…...

在 Linux 中开启 Flask 项目持续运行

在 Linux 中开启 Flask 项目持续运行 在部署 Flask 项目时&#xff0c;情况往往并不是那么理想。默认情况下&#xff0c;关闭 SSH 终端后&#xff0c;Flask 服务就停止了。这时&#xff0c;您需要找到一种方法在 Linux 服务器上实现持续运行 Flask 项目&#xff0c;并在服务器…...

考研个人经验总结【心理向】

客官你好 首先&#xff0c;不管你是以何种原因来到这篇博客&#xff0c;以下内容或多或少可能带给你一些启发。如果你还是大二or大三学生&#xff0c;有考研的打算&#xff0c;不妨提前了解一些考研必备的心理战术&#xff0c;有时候并不是你知识学得不好&#xff0c;而是思维…...

如何在CentOS安装SQL Server数据库并通过内网穿透工具实现公网访问

文章目录 前言1. 安装sql server2. 局域网测试连接3. 安装cpolar内网穿透4. 将sqlserver映射到公网5. 公网远程连接6.固定连接公网地址7.使用固定公网地址连接 前言 简单几步实现在Linux centos环境下安装部署sql server数据库&#xff0c;并结合cpolar内网穿透工具&#xff0…...

jupyter内核错误

1、在dos窗口输入以下命令激活环境&#xff1a;anaconda activate 【py环境名&#xff0c;比如py37】&#xff08;目的是新家你一个虚拟环境&#xff09; 2、在虚拟环境py37下安装jupyter notebook&#xff0c;命令&#xff1a;pip install jupyter notebook 3、安装ipykerne…...

设计模式的艺术P1基础—2.3 类之间的关系

设计模式的艺术P1基础—2.3 类之间的关系 在软件系统中&#xff0c;类并不是孤立存在的&#xff0c;类与类之间存在各种关系。对于不同类型的关系&#xff0c;UML提供了不同的表示方式 1&#xff0e;关联关系 关联&#xff08;Association&#xff09;关系是类与类之间最常用…...

工业无人机行业研究:预计2025年将达到108.2亿美元

近年来&#xff0c;在技术进步和各行各业对无人驾驶飞行器 (UAV) 不断增长的需求的推动下&#xff0c;工业无人机市场一直在快速增长。该市场有望在未来几年继续其增长轨迹&#xff0c;许多关键趋势和因素推动其发展。 在全球范围内&#xff0c;工业无人机市场预计到 2025 年将…...

PCA主成分分析算法

在数据分析中&#xff0c;如果特征太多&#xff0c;或者特征之间的相关性太高&#xff0c;通常可以用PCA来进行降维。比如通过对原有10个特征的线性组合, 我们找出3个主成分&#xff0c;就足以解释绝大多数的方差&#xff0c;该算法在高维数据集中被广泛应用。 算法&#xff08…...

Hyperledger Fabric 权限策略和访问控制

访问控制是区块链网络十分重要的功能&#xff0c;负责控制某个身份在某个场景下是否允许采取某个操作&#xff08;如读写某个资源&#xff09;。 常见的访问控制模型包括强制访问控制&#xff08;Mandatory Access Control&#xff09;、自主访问控制&#xff08;Discretionar…...

Day28 回溯算法part04 93. 复原IP地址 78. 子集 90. 子集 II

回溯算法part04 93. 复原IP地址 78. 子集 90. 子集 II 93. 复原 IP 地址 class Solution { private:vector<string> result;bool isValid(string& s,int start,int end){if (start > end) return false;if (s[start] 0 && start ! end) { // 0开头的数…...

Linux系统常用的安全优化

环境&#xff1a;CentOS7.9 1、禁用SELinux SELinux是美国国家安全局对于强制访问控制的实现 1)永久禁用SELinux vim /etc/selinux/config SELINUXdisabled #必须重启系统才能生效2&#xff09;临时禁用SELInux getenforce #查看SELInux当前状态 setenforce 0 #数字…...

Vue-4、单向数据绑定与双向数据绑定

1、单向数据绑定 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><title>数据绑定</title><!--引入vue--><script type"text/javascript" src"https://cdn.jsdelivr.net/npm/…...

【Flutter 开发实战】Dart 基础篇:常用运算符

在Dart中&#xff0c;运算符是编写任何程序的基本构建块之一。本文将详细介绍Dart中常用的运算符&#xff0c;以帮助初学者更好地理解和运用这些概念。 1. 算术运算符 算术运算符用于执行基本的数学运算。Dart支持常见的加、减、乘、除、整除以及取余运算。常见的算数运算符如…...

C++:ifstream通过getline读取文件会忽略最后一行空行

getline是读取文件的常用函数,虽然使用简单,但是有一个较容易被忽视的问题,就是文件最后一行空行会被忽略。 #include <iostream> #include <fstream> #include <string> using namespace std;void readWholeFileWithGetline(string fileName) {string t…...

力扣123. 买卖股票的最佳时机 III

动态规划 思路&#xff1a; 最多可以完成两笔交易&#xff0c;因此任意一天结束后&#xff0c;会处于5种状态&#xff1a; 未进行任何操作&#xff1b;只进行了一次买操作&#xff1b;进行了一次买操作和一次卖操作&#xff1b;再完成了一次交易之后&#xff0c;进行了一次买操…...

rknn优化教程(二)

文章目录 1. 前述2. 三方库的封装2.1 xrepo中的库2.2 xrepo之外的库2.2.1 opencv2.2.2 rknnrt2.2.3 spdlog 3. rknn_engine库 1. 前述 OK&#xff0c;开始写第二篇的内容了。这篇博客主要能写一下&#xff1a; 如何给一些三方库按照xmake方式进行封装&#xff0c;供调用如何按…...

SciencePlots——绘制论文中的图片

文章目录 安装一、风格二、1 资源 安装 # 安装最新版 pip install githttps://github.com/garrettj403/SciencePlots.git# 安装稳定版 pip install SciencePlots一、风格 简单好用的深度学习论文绘图专用工具包–Science Plot 二、 1 资源 论文绘图神器来了&#xff1a;一行…...

在四层代理中还原真实客户端ngx_stream_realip_module

一、模块原理与价值 PROXY Protocol 回溯 第三方负载均衡&#xff08;如 HAProxy、AWS NLB、阿里 SLB&#xff09;发起上游连接时&#xff0c;将真实客户端 IP/Port 写入 PROXY Protocol v1/v2 头。Stream 层接收到头部后&#xff0c;ngx_stream_realip_module 从中提取原始信息…...

OkHttp 中实现断点续传 demo

在 OkHttp 中实现断点续传主要通过以下步骤完成&#xff0c;核心是利用 HTTP 协议的 Range 请求头指定下载范围&#xff1a; 实现原理 Range 请求头&#xff1a;向服务器请求文件的特定字节范围&#xff08;如 Range: bytes1024-&#xff09; 本地文件记录&#xff1a;保存已…...

解读《网络安全法》最新修订,把握网络安全新趋势

《网络安全法》自2017年施行以来&#xff0c;在维护网络空间安全方面发挥了重要作用。但随着网络环境的日益复杂&#xff0c;网络攻击、数据泄露等事件频发&#xff0c;现行法律已难以完全适应新的风险挑战。 2025年3月28日&#xff0c;国家网信办会同相关部门起草了《网络安全…...

Bean 作用域有哪些?如何答出技术深度?

导语&#xff1a; Spring 面试绕不开 Bean 的作用域问题&#xff0c;这是面试官考察候选人对 Spring 框架理解深度的常见方式。本文将围绕“Spring 中的 Bean 作用域”展开&#xff0c;结合典型面试题及实战场景&#xff0c;帮你厘清重点&#xff0c;打破模板式回答&#xff0c…...

pikachu靶场通关笔记19 SQL注入02-字符型注入(GET)

目录 一、SQL注入 二、字符型SQL注入 三、字符型注入与数字型注入 四、源码分析 五、渗透实战 1、渗透准备 2、SQL注入探测 &#xff08;1&#xff09;输入单引号 &#xff08;2&#xff09;万能注入语句 3、获取回显列orderby 4、获取数据库名database 5、获取表名…...

[论文阅读]TrustRAG: Enhancing Robustness and Trustworthiness in RAG

TrustRAG: Enhancing Robustness and Trustworthiness in RAG [2501.00879] TrustRAG: Enhancing Robustness and Trustworthiness in Retrieval-Augmented Generation 代码&#xff1a;HuichiZhou/TrustRAG: Code for "TrustRAG: Enhancing Robustness and Trustworthin…...

小木的算法日记-多叉树的递归/层序遍历

&#x1f332; 从二叉树到森林&#xff1a;一文彻底搞懂多叉树遍历的艺术 &#x1f680; 引言 你好&#xff0c;未来的算法大神&#xff01; 在数据结构的世界里&#xff0c;“树”无疑是最核心、最迷人的概念之一。我们中的大多数人都是从 二叉树 开始入门的&#xff0c;它…...

【安全篇】金刚不坏之身:整合 Spring Security + JWT 实现无状态认证与授权

摘要 本文是《Spring Boot 实战派》系列的第四篇。我们将直面所有 Web 应用都无法回避的核心问题&#xff1a;安全。文章将详细阐述认证&#xff08;Authentication) 与授权&#xff08;Authorization的核心概念&#xff0c;对比传统 Session-Cookie 与现代 JWT&#xff08;JS…...