day02 初学c++第二章

2024-08-21 19:28
文章标签 c++ 初学 第二章 day02

本文主要是介绍day02 初学c++第二章,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

if语句程序中的判断

语法:

if(条件判断){

        如果判断结果为true,会执行的代码;

}else if(条件判断2){

        条件2为true,会执行的代码;

}else if(条件判断N){

        条件N为true,会执行的代码;
}else{

        上诉判断全部为false,会执行的代码

}

注意:判断条件可以是数字1或0(bool类型的实质就是0或1)

    bool xiaomei = false;int xiaotian = 0;int xiaoqing = 1;if(xiaomei){//打印xiaomei,i love youcout << "xiaomei,i love you" << endl;}else if(xiaotian){//打印小甜我喜欢你cout << "xiaotian,i love you" << endl;}else if(xiaoqing){//打印小青我喜欢你cout << "xiaoqing,i love you" << endl;//xiaoqing,i love you}else{//打印小明我喜欢你cout << "xiaoming,i love you" << endl;}

构建产生随机数的代码

在代码中#include "random"

然后构造一个方法,放置在main函数之前,即可调用get_random_num函数

//能得到随机数字
int get_random_number(int min, int max){//创建一个随机数产生器random_device rd;mt19937 gen(rd());//定义一个均匀分布的整数范围uniform_int_distribution<> dis(min, max);//生成一个随机数并输出return dis(gen);
}

在main函数中输入int num = get_random_num(1,10)即可得到1~10的随机数

案例

需求:

· 随机产生3份信息

· 第一份信息:1~10的数字,代表扑克牌1~10

· 第二份信息:字符串,红色或黑色,代表扑克牌的花色

· 第三份信息:字符串,如果是红色产出红桃或方块,如果是黑色产出黑桃或梅花

· 案例要求:

· 通过嵌套判断,并结合判断语句猜测上诉信息,如

· 先猜数字,成功后猜颜色,再成功猜测具体的花型

#include <iostream>
#include "random"
using namespace std;//能得到随机数字
int get_random_number(int min, int max) {//创建一个随机数产生器random_device rd;mt19937 gen(rd());//定义一个均匀分布的整数范围uniform_int_distribution<> dis(min, max);//生成一个随机数并输出return dis(gen);
}int main() {int num = get_random_number(1, 10);//true、false的实质就是1、0string color = get_random_number(0, 1)? "红色" : "黑色";string suit;if (color == "红色") suit = get_random_number(0, 1)? "红桃" : "方块";else suit = get_random_number(0, 1)? "黑桃" : "梅花";cout << num << " " + color << " " + suit << endl;int num_input;cin >> num_input;if (num_input == num) {//过了第一关string color_input;cin >> color_input;if (color_input == color) {//过了第二关string suit_input;cin >> suit_input;if (suit_input == suit) {//全部通过cout << "恭喜你,挑战成功" << endl;}else cout << "很可惜,最后挑战失败" << endl;}else cout << "第二关挑战失败" << endl;}else cout << "第一关挑战失败" << endl;return 0;
}

switch控制语句

介绍

它在功能上和if、else if的组合使用基本一致,只是提供了另外一种更为简洁的针对多条件判断的写法

语法

注意:

· expression为常量表达式,应当给予一个常量值;类型应当为整型(int、short、char)和枚举类型 

· switch仅做值匹配(相等判断),break语句可以中断switch语句,否则向下执行其他case段(包括default段,不会与其他expression_N进行比较),直至执行完或遇到break为止。

案例

需求:

给电影打分,10和9是优秀,8和7是一般,6和5是普通,低于5是垃圾,请用switch语句完成

int main() {int num;cout << "请给电影打分,10和9是优秀,7和8是一般,6和5是普通,低于5是垃圾" << endl;cin >> num;switch (num) {case 10:case 9:cout << "优秀" << endl; break;case 8:case 7:cout << "一般" << endl; break;case 6:case 5:cout << "普通" << endl; break;default:cout << "垃圾" << endl; break;}return 0;
}

枚举类型

介绍

枚举:本质上是一个被命名整型常数的集合

· 在c\c++语言中它是一种基本数据类型

· 其主要作用是提高代码的可读性、可维护性和键入性

· 因为枚举可以将一些数字或字符串符号化,以此增强程序的可读性和可维护性

语法

枚举类型每一个元素,都有整数标号,默认从0开始递增。即上述代码SPRING本质是数字0,SUMMER是2,以此类推。

起始标号可以自行设置,如在enum Season中,SPRING后边加个“=3”,表示从3开始递增

int main() {enum Season {SPRING,SUMMER,AUTUMN,WINTER};cout << "请输入,0春天,1夏天,2秋天,3冬天" << endl;int num;cin >> num;switch (num) {case SPRING:cout << "春天" << endl; break;case SUMMER:cout << "夏天" << endl; break;case AUTUMN:cout << "秋天" << endl; break;case WINTER:cout << "冬天" << endl; break;default:cout << "输入错误" << endl; break;}return 0;
}

while循环语句

程序中的循环

while(条件表达式){

//循环体,当条件表达式为真时执行

code;
}

注意:

· while循环需要提供判断表达式,只要表达式结果为true就会一直运行下去

案例

猜数字

需求:设置一个范围1~100的随机整数变量,通过while循环,配合cin语句,判断输入的数字是否等于随机数

· 无限次机会,直到猜中为止

· 没一次猜不中,会提示大了或小了

· 猜完数字后,提示猜了几次

int main() {//生成一个随机数int num = get_random_number(1, 100);//定义一个计数器int count = 0;int num_input;cout << "请输入你要猜的数字" << endl;while (true) {cin >> num_input;if (num_input > num) { count++; cout << "大了,你已经猜了" << count <<  "次" << endl; }else if (num_input < num) { count++; cout << "小了,你已经猜了" << count << "次" << endl; }else {count++;cout << "恭喜你,你猜了" << count << "次,猜中了!!" << endl;break;}}return 0;
}

九九乘法表

#include <iostream>
using namespace std;int main() {int i = 1;while (i <= 9) {int j = 0;while (j < i) {if (j == i - 1)cout << (j + 1) << "*" << i << "=" << (j+1)*i << "\t" << endl;else cout << (j + 1) << "*" << i << "=" << (j + 1) * i << "\t";j++;}i++;}return 0;
}

for循环语句

语句

for(循环因子初始化语句;条件判断;循环因子变化语句){

code;

...
}

注意:for循环的循环因子初始化、条件判断、循环因子更新三部分是语法功能但不是强制要求,可根据需要提供或不提供

跳转语句

break语句:

  • 出现在switch条件语句中,作用是终止Case并跳出Switch
  • 出现在循环语句中,作用是跳出当前的循环语句
  • 出现在嵌套循环中,跳出最近的内层循环语句

continue语句:

  • 在循环语句中,跳过本次循环中余下尚未执行的语句,继续执行下一次循环

goto语句:

  • 无条件跳转语句

语法:goto 标记;(如果标记的名称存在,执行到goto语句时,会跳转到标记的位置)

int main() {cout << "hello c++ " << endl;cout << "hello c" << endl;goto FLAG;cout << "hello c#" << endl;cout << "hello java" << endl;FLAG:cout << "hello python" << endl;return 0;//hello c++//hello c//hello python
}

这篇关于day02 初学c++第二章的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1094066

相关文章

【C++ Primer Plus习题】13.4

大家好,这里是国中之林! ❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看← 问题: 解答: main.cpp #include <iostream>#include "port.h"int main() {Port p1;Port p2("Abc", "Bcc", 30);std::cout <<

C++包装器

包装器 在 C++ 中,“包装器”通常指的是一种设计模式或编程技巧,用于封装其他代码或对象,使其更易于使用、管理或扩展。包装器的概念在编程中非常普遍,可以用于函数、类、库等多个方面。下面是几个常见的 “包装器” 类型: 1. 函数包装器 函数包装器用于封装一个或多个函数,使其接口更统一或更便于调用。例如,std::function 是一个通用的函数包装器,它可以存储任意可调用对象(函数、函数

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

06 C++Lambda表达式

lambda表达式的定义 没有显式模版形参的lambda表达式 [捕获] 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 有显式模版形参的lambda表达式 [捕获] <模版形参> 模版约束 前属性 (形参列表) 说明符 异常 后属性 尾随类型 约束 {函数体} 含义 捕获:包含零个或者多个捕获符的逗号分隔列表 模板形参:用于泛型lambda提供个模板形参的名

6.1.数据结构-c/c++堆详解下篇(堆排序,TopK问题)

上篇:6.1.数据结构-c/c++模拟实现堆上篇(向下,上调整算法,建堆,增删数据)-CSDN博客 本章重点 1.使用堆来完成堆排序 2.使用堆解决TopK问题 目录 一.堆排序 1.1 思路 1.2 代码 1.3 简单测试 二.TopK问题 2.1 思路(求最小): 2.2 C语言代码(手写堆) 2.3 C++代码(使用优先级队列 priority_queue)

【C++高阶】C++类型转换全攻略:深入理解并高效应用

📝个人主页🌹:Eternity._ ⏩收录专栏⏪:C++ “ 登神长阶 ” 🤡往期回顾🤡:C++ 智能指针 🌹🌹期待您的关注 🌹🌹 ❀C++的类型转换 📒1. C语言中的类型转换📚2. C++强制类型转换⛰️static_cast🌞reinterpret_cast⭐const_cast🍁dynamic_cast 📜3. C++强制类型转换的原因📝

C++——stack、queue的实现及deque的介绍

目录 1.stack与queue的实现 1.1stack的实现  1.2 queue的实现 2.重温vector、list、stack、queue的介绍 2.1 STL标准库中stack和queue的底层结构  3.deque的简单介绍 3.1为什么选择deque作为stack和queue的底层默认容器  3.2 STL中对stack与queue的模拟实现 ①stack模拟实现

c++的初始化列表与const成员

初始化列表与const成员 const成员 使用const修饰的类、结构、联合的成员变量,在类对象创建完成前一定要初始化。 不能在构造函数中初始化const成员,因为执行构造函数时,类对象已经创建完成,只有类对象创建完成才能调用成员函数,构造函数虽然特殊但也是成员函数。 在定义const成员时进行初始化,该语法只有在C11语法标准下才支持。 初始化列表 在构造函数小括号后面,主要用于给

2024/9/8 c++ smart

1.通过自己编写的class来实现unique_ptr指针的功能 #include <iostream> using namespace std; template<class T> class unique_ptr { public:         //无参构造函数         unique_ptr();         //有参构造函数         unique_ptr(