C++string的使用
· CSDN的uu们,大家好。这里是C++入门的第十六讲。
· 座右铭:前路坎坷,披荆斩棘,扶摇直上。
· 博客主页: @姬如祎
· 收录专栏:C++专题
目录
1.构造函数
1.1 string()
1.2 string(const char* s)
1.3 string(const char* s, size_t n)
1.4 string(size_t n, char c)
1.5 string (const string& str)
1.6 string (const string& str, size_t pos, size_t len = npos)
2. size_t size() const
3. size_t length() const
4. size_t max_size() const
5. resize
5.1 void resize (size_t n)
编辑5.2 void resize (size_t n, char c)
6. size_t capacity() const
7: void reserve (size_t n = 0)
8. void clear()
9. bool empty() const
10. operator[]
11. char at(size_t pos)
12. char& back()
13. char& front()
14. operator+=
15. string& append (const char* s)
编辑
16. void push_back (char c)
17. insert()
17.1 string& insert (size_t pos, const char* s)
17.2 string& insert (size_t pos, size_t n, char c)
18. string& erase (size_t pos = 0, size_t len = npos)
19. void pop_back()
20. const char* c_str() const
21. find()
21.1 size_t find (const char* s, size_t pos = 0) const
21. 2 size_t find (char c, size_t pos = 0) const
22. rfind()
编辑
22.1 size_t rfind (const char* s, size_t pos = npos) const
22.2 size_t rfind (char c, size_t pos = npos) const
23. string substr (size_t pos = 0, size_t len = npos) const
1.构造函数
1.1 string()
这是 string 的无参构造,在 string 的底层就是构造了一个空字符串:“”,即在下标为 0 的位置存储了一个 '\0' 。
#include<iostream>
#include<string>
using namespace std;int main()
{string s;cout << s;return 0;
}
这是VS2022下看到的结果。VS对 string 的封装比较复杂,他一上来就开了很多空间,并且直接把开辟出来的空间全部初始化为了0。我们看到的现象会因编译器的不同有所差异。
1.2 string(const char* s)
这个构造函数表示可以使用常量字符串来初始化 string!或者使用字符数组来初始化,字符数组的数组名也是 char* 类型的嘛,char* 是可以用const char* 来接收的。
#include<iostream>
#include<string>
using namespace std;int main()
{string s("csdn yyds!");cout << s << endl; //输出:csdn yyds!char arr[12] = { 'c', 's', 'd', 'n', ' ','y' ,'y', 'd', 's', '!'};string s1(arr);cout << s1 << endl; //输出:csdn yyds!}
1.3 string(const char* s, size_t n)
这个构造函数表示可以使用一个常量字符串 或者 字符数组的前 n 个字符来初始化 string。
#include<iostream>
#include<string>
using namespace std;int main()
{string s("csdn yyds!", 4);cout << s << endl; //输出:csdnchar arr[10] = { 'c', 's', 'd', 'n', ' ','y' ,'y', 'd', 's' };string s1(arr, 4);cout << s1 << endl; //输出:csdn
}
1.4 string(size_t n, char c)
这个构造函数表示可以用 n 个 字符 来构造一个string对象。
#include<iostream>
#include<string>
using namespace std;int main()
{string s(8, '8');cout << s << endl; //输出:88888888
}
1.5 string (const string& str)
这个构造函数表示可以使用另一个string对象来构造一个string对象(拷贝构造)。
#include<iostream>
#include<string>
using namespace std;int main()
{string s("csdn yyds!");string s1(s);cout << s1 << endl; //输出:csdn yyds!
}
1.6 string (const string& str, size_t pos, size_t len = npos)
这个构造函数表示可以用另一个 string 对象 从 pos 位置开始截取 n 个字符来构造一个 string 对象。
我们看到 len 参数有个缺省值:npos。这个 npos 是定义在 string 类中一个public属性的静态常量,其值为 -1。但是因为 len 的类型为无符号的整形,因此 len 的实际大小是无符号整形的最大值。我们可以直接打印 npos :
#include<iostream>
#include<string>
#include<climits>
using namespace std;int main()
{cout << (int)string::npos << endl; //int输出的nposcout << string::npos << endl; //size_t输出的nposcout << UINT32_MAX << endl; //32位机器下无符号整形的最大值}
当我们的 pos + len 大于参数一字符串的长度时就是截取 pos 位置后的全部字符来构造string。不传 len ,len = npos 那可是相当大呢!所以不传 len 就是截取 pos 后面的全部字符来构造string。
#include<iostream>
#include<string>
using namespace std;int main()
{string s("csdn yyds!");string s1(s, 5, 4); //从下标为 5 的位置(第一个y)向后截取 4 个字符来构造一个stringcout << s1 << endl; //输出 yydsstring s2(s, 5, 188); //len 传入很大cout << s2 << endl; //输出 yyds!string s3(s, 5); //不传lencout << s3 << endl; //输出 yyds!}
2. size_t size() const
这个函数用于返回一个 string 对象存储的有效字符的数量。为什么要有后面的那个const呢?我们知道这个const是修饰 *this 的,加上const 常对象与普通对象都可以调用啦!
#include<iostream>
#include<string>
using namespace std;int main()
{string s1("I love scdn!");cout << s1.size() << endl; //输出:12const string s2("csdn yyds!");cout << s2.size() << endl; //输出:10}
3. size_t length() const
这个接口跟 size_t size() const 实现的效果是一毛一样的!那你就可能会问了,为什么设计者要搞出来两个功能相同的接口呢?那是因为 string 类的出现早于 STL 库,string 在很久以前是没有 size() 这个接口的。但是呢 STL出现以后,求容器的大小都是实现的 size(), 于是 string 就也加上了一个 size() 接口!
4. size_t max_size() const
这个函数返回 一个string 对象多能存储的最多的字符数量,每个编译器的结果不尽相同!此函数用得也不多!
5. resize
5.1 void resize (size_t n)
在 string 的底层维护了一个字符数组,一个表示有效字符个数的size,和字符数组实际的容量capacity。而 resize 函数就是用来改变有效字符的个数的函数。
情况1:当 n 小于原字符串的大小,底层实现很简单,直接改变size,在添加一个 '\0' 表示字符的结束即可! 因此会保留原字符串的数据。
#include<iostream>
#include<string>
using namespace std;int main()
{string s1("csdn yyds");s1.resize(4);cout << s1 << endl; //输出:csdncout << s1.size() << endl; //输出:4}
通过调试观察 string 的内存,也可以证明我的描述:
情况2: 当 n 大于原字符串的大小。会将原字符串的 size 扩展到相应的大小,但是在 VS2022 上,多余的空间他会全部初始化为 0 ,resize 之后的字符串的打印结果与原来并无不同。但是可以通过打印 size 来观察不同!
#include<iostream>
#include<string>
using namespace std;int main()
{string s1("csdn yyds!");cout << s1.size() << endl; //resize之前输出:10s1.resize(20);cout << s1 << endl; //输出:csdn yyds!cout << s1.size() << endl; //输出:20
}
通过观察 string 内存,能够证实我的讲解:
5.2 void resize (size_t n, char c)
这是一个重载的版本,在改变字符串大小的同时增加了初始化的功能!这个初始化的功能仅在 n 的大小大于原字符串的大小时生效(也就是 5.1 情况二的时候生效。)
#include<iostream>
#include<string>
using namespace std;int main()
{string s1("csdn yyds!");s1.resize(20, 'a');cout << s1 << endl; //输出: csdn yyds!aaaaaaaaaacout << s1.size() << endl;//输出:20
}
6. size_t capacity() const
我们刚才提到 string 的底层维护了一个 capacity 用来表示字符数组的实际大小,这个函数就是用来返回这个 capacity 的。此函数用得也不多!
不同编译器对于 string 维护的数组开空间的规则不同,因此返回相同字符串的capacity,不同编译器得到的值也不一定相同。下面是VS2022的结果:
#include<iostream>
#include<string>
using namespace std;int main()
{string s;cout << s.capacity() << endl; //输出:15
}
7: void reserve (size_t n = 0)
这个函数是用来改变 string 维护的字符数组的实际容量的。
8. void clear()
清空一个字符串的内容,使之变为空串!
9. bool empty() const
判断一个字符串是不是空串!
10. operator[]
operator[] 能够使得字符串支持下标访问,这个是平时用得非常多的!他提供了两个版本,一个是非const版本,一个是const版本。const 修饰的string对象,通过下标访问得到的字符不允许修改。而非const的string对象通过下标访问得到的字符可以修改。
#include<iostream>
#include<string>
using namespace std;int main()
{string s1("hello world");s1[5] = '#';cout << s1 << endl; //输出:hello#world
}
const修饰的string对象不可修改:
11. char at(size_t pos)
此函数完全可以被operator[]代替哈,at函数返回的是下标为 pos 的字符。 同样也有const版本和非const版本。
12. char& back()
该函数返回字符串的最后一个字符,同样也有 const 和非const 两个版本。
const版本:const char& back() const
非const版本:char& back()
#include<iostream>
#include<string>
using namespace std;int main()
{string s1("hello world");char& tail = s1.back(); //非const支持修改tail = 'C';cout << s1 << endl;//输出:hello worlC
}
13. char& front()
该函数返回字符串的第一个字符,同样有 const 和非 const 两个版本。
const char& front() const
char& front()
14. operator+=
string 重载了 += 运算符,支持一个字符串加等一个字符,一个字符串常量,一个string 对象。
#include<iostream>
#include<string>
using namespace std;int main()
{string s("csdn yyds!");s += 'a';cout << s << endl; //输出:csdn yyds!as += "bbb";cout << s << endl; //输出:csdn yyds!abbbstring tmp("ccc");s += tmp;cout << s << endl; //输出:csdn yyds!abbbccc
}
15. string& append (const char* s)
往一个string对象的末尾追加一个 常量字符串 或者 数组。
#include<iostream>
#include<string>
using namespace std;int main()
{string s1("hello ");s1.append("world");cout << s1 << endl; //输出:hello world
}
我们查阅 资料 发现 append 重载了很多版,是不是觉得string的设计有点冗余。个人感觉最好用的还是operator+=。
16. void push_back (char c)
往string后面追加一个字符,只能说非常鸡肋。不如operator+=。
17. insert()
我们可以看到 insert 重载了巨多版本,真令人头大呢!我们就讲讲两个具有代表性的。其他的都大同小异。
17.1 string& insert (size_t pos, const char* s)
该函数用于在pos位置插入一个 常量字符串 或者 字符数组(字符数组一定要有 '\0' 哦)。
#include<iostream>
#include<string>
using namespace std;int main()
{string s1("hello csdn");s1.insert(5, " hi"); //在下标为5的位置插入 hicout << s1 << endl; //输出:hello hi csdn}
17.2 string& insert (size_t pos, size_t n, char c)
该函数用于在pos位置插入n个相同的字符。
#include<iostream>
#include<string>
using namespace std;int main()
{string s1("hello csdn");s1.insert(5, 5, '1'); //在下标为5的位置插入5个'1'cout << s1 << endl; //输出:hello11111 csdn}
18. string& erase (size_t pos = 0, size_t len = npos)
这个函数可以将从pos位置开始,后面的len个字符全部删除,不传len,表示len很大,也就是移除pos后面的所有字符啦!
#include<iostream>
#include<string>
using namespace std;int main()
{string s1("hello csdn");s1.erase(0, 6); //移除下标 0 后面的6个字符cout << s1 << endl; //输出:csdnstring s2("hello csdn");s2.erase(1); //移除下标1后的所有字符cout << s2 << endl; //输出:h}
19. void pop_back()
这个函数简单,删除string的最后那个字符。
20. const char* c_str() const
这个函数可以返回 C风格的字符串。
#include<iostream>
#include<string>
using namespace std;int main()
{string s1("hello csdn");const char* s = s1.c_str();cout << s << endl; //输出:hello csdnreturn 0;
}
C风格的字符串:char类型的数组,每个下标对应一个字符,末尾有一个 '\0'。
21. find()
find 重载的版本也是比较多的呢!老规矩讲常用的!
21.1 size_t find (const char* s, size_t pos = 0) const
这个函数用来在一个string中,从pos位置开始查找一个常量字符串。pos不传的话就是从头查找。如果查找到了,返回起始下标,如果没有查找到返回 npos 。
#include<iostream>
#include<string>
using namespace std;int main()
{string s1("hello csdn");//从下标为1的位置开始查找 csdn 这个常量字符串cout << s1.find("csdn", 1) << endl; //输出:6//从下标为7的位置开始查找 csdn 这个常量字符串cout << s1.find("csdn", 7) << endl; //输出:4294967295(这是无符号整形的最大值)cout << (int)s1.find("csdn", 7) << endl; //输出:-1}
21. 2 size_t find (char c, size_t pos = 0) const
这个函数用来在一个string中,从pos位置开始查找字符 c。pos不传就是从头开始查找。一旦查找成功 (即从pos位置开始第一个字符 c ),返回查找成功的下标,否则返回 npos。
#include<iostream>
#include<string>
using namespace std;int main()
{string s1("hello csdn");//从下标为 1 的位置开始查找字符'l'cout << s1.find('l', 1) << endl; //输出:2//从下标为 4 的位置开始查找字符'l'cout << s1.find('l', 4) << endl; //输出:4294967295(这是无符号整形的最大值)cout << (int)s1.find('l', 4) << endl; //输出:-1
}
22. rfind()
我们可以看到参数的形式跟find完全一样!rfind只是从后往前找罢了!
22.1 size_t rfind (const char* s, size_t pos = npos) const
表示:在 string 对象中从pos位置往前,查找常量字符串 s 。pos不传就是从末尾向前查找。查找成功,返回起始位置的下标,查找失败,返回 npos。
#include<iostream>
#include<string>
using namespace std;int main()
{string s1("hello csdn");//从下标为 8 的位置往前,查找常量字符串 csdncout << s1.rfind("csdn", 8) << endl; //输出:6//从下标为 5 的位置往前,查找常量字符串 csdncout << s1.rfind("csdn", 5) << endl; //输出:4294967295(这是无符号整形的最大值)cout << (int)s1.rfind("csdn", 5); //输出:-1}
22.2 size_t rfind (char c, size_t pos = npos) const
表示:从pos位置开始向前查找字符 c 。pos不传就是从末尾向前查找。一旦查找成功 (pos位置往前,第一个字符c的下标) 返回该下标,否则返回 npos。
#include<iostream>
#include<string>
using namespace std;int main()
{string s1("hello csdn");//从下标为 8 的位置开始向前查找字符'c'cout << s1.rfind('c', 8) << endl; //输出:6//从下标为 5 的位置开始向前查找字符'c'cout << s1.rfind('c', 5) << endl; //输出:4294967295(这是无符号整形的最大值)cout << (int)s1.rfind('c', 5) << endl; //输出:-1
}
23. string substr (size_t pos = 0, size_t len = npos) const
这是用截取原string对象中的一部分连续字符,返回一个新的string对象。简言之:获取子串。
表示:从 pos 位置开始截取 len 个长度的字符来构造新的string。pos不传默认从头开始截取。len不传默认截取到末尾。
#include<iostream>
#include<string>
using namespace std;int main()
{string s1("hello csdn");//不传len,默认截取到末尾,从 6 截取到末尾cout << s1.substr(6) << endl; //输出:csdn//从 0 开始截取 5 个字符cout << s1.substr(0, 5) << endl; //输出 hello
}
总结:不需要死记硬背,用得多了自然就记得了!string的接口真的很多,记不起来查查文档就知道了!
string - C++ Reference (cplusplus.com)
相关文章:

C++string的使用
CSDN的uu们,大家好。这里是C入门的第十六讲。 座右铭:前路坎坷,披荆斩棘,扶摇直上。 博客主页: 姬如祎 收录专栏:C专题 目录 1.构造函数 1.1 string() 1.2 string(const char* s) 1.3 string(const …...
闲着也是闲着,自己写歌东西玩一玩,碰碰脑子,简单快乐一点,双人出数的小游戏,后续还带补充
主旨就是每个人出一个数,目前限制两人,之后考虑多人,然后对其取差值,获取到一个结果,比对结果的奇偶数,还可以看下两人出同一个数的概率,反正概率上是一个比较稳定的。 当然自己想玩的活也可以做…...

牛客网 -- WY28 跳石板
题目链接: 跳石板_牛客题霸_牛客网 (nowcoder.com) 解题步骤: 参考代码: void get_approximate(vector<int>& v,int n) {//求约数,从2到sqrt(n)即可,原因看图解//这里一定要等于sqrt(n),例如16…...

[正式学习java③]——字符串在内存中的存储方式、为什么字符串不可变、字符串的拼接原理,键盘录入的小细节。
一、字符串 1.字符串在内存中的存储方式 🔥在java中,内存中有两个地方可以存储字符串,一个是字符串池,一个是堆内存,串池中的字符串不会重复,而堆中的字符串每次都会开辟一块新的空间,因为维护…...

行情分析——加密货币市场大盘走势(10.18)
大饼昨日小幅度的下跌回调了,很快又上涨。目前看下来震荡向下刚刚开始,可以关注后续情况。大饼依然保持看空不做空,目前除了独立行情的币,就大饼非常强势。目前从MACD日线来看,还是保持多头趋势,预计明后两…...

高并发场景下常见的限流算法及方案介绍
应用场景 现代互联网很多业务场景,比如秒杀、下单、查询商品详情,最大特点就是高并发,而往往我们的系统不能承受这么大的流量,继而产生了很多的应对措施:CDN、消息队列、多级缓存、异地多活。 但是无论如何优化&…...

虹科分享 | 选择SAS还是NVMe?虹科网络基础带您一探究竟!
存储架构师需要通过确保他们选择的存储解决方案提供支持其生态系统所需的安全性、稳定性、可扩展性和管理特性来应对当今的业务挑战。当他们考虑采用新的存储技术时,在采用新技术之前,他们应该权衡和审查一些基本的考虑因素。新的存储协议不断进入市场&a…...

在ERP管理系统中,库存管理的基本流程是什么?
在ERP管理系统中,库存管理的基本流程是什么? 下面我就以我们公司正在用的简道云库存管理系统为例,为大家进行库存管理基本流程的演示 这个系统是我们公司自己搭建的,大家如果有需要可以自取,也可以在模板的基础上自行…...
Ruby 之 csv 文件读写
csv 文件写入 require csvtitle ["col1", "col2"] contents [["row11", "row12"], ["row21", "row22"]]csv1 CSV.open("test1.csv", "wb") do |csv|# write file titlecsv << titl…...
Android AMS——进程LRU列表更新(十七)
AMS对进程的管理主要体现在两个方面: 进程LRU列表动态更新:动态调整进程在mLruProcesses列表的位置进程优先级动态调整:实际是调整进程oom_adj的值。 这两项调整和系统进行自动回收有关,当内存不足时,系统会关闭一些进程来释放内存,下面就依据这两方面来看…...

【数据可视化】—大屏数据可视化展示
【数据可视化】—大屏数据可视化展示 一、数据可视化 数据可视化的目的:借助于图形化工具,清晰有效的传达与沟通信息。 数据可视化可以把数据从冰冷的数字转换成图形,揭示蕴含在数据中的规律和道理。 二、 免费数据可视化库 Echarts 百度…...

计算机算法分析与设计(12)---贪心算法(最优装载问题和哈夫曼编码问题)
文章目录 一、最优装载问题1.1 问题表述1.2 代码编写 二、哈夫曼编码2.1 哈夫曼编码概述2.2 前缀码2.3 问题描述2.4 代码思路2.5 代码编写 一、最优装载问题 1.1 问题表述 1. 有一批集装箱要装上一艘载重量为 c c c 的轮船,已知集装箱 i ( 1 ≤ i ≤ n ) i(1≤i≤…...

打造属于自己的vue图标库
hfex-icon图标库 Install npm i -D hfex-icon主要提供2种使用方式 方式一 通过svg图标资源,借助unplugin-icons库将svg图标文件生成vue组件,然后通过vue组件的引入方式在vue中使用 unplugin-icons 兼容vue2和vue3 在vue.config.js的plugins中配置…...
C++11线程池
使用 condition_variable::wait(unique_lock<mutex>&lck, Predicate pred) 时,必须保证条件变量通过notify唤醒的同时,wait 的第二个参数 Predicate 返回 true 了才可以往下走。必须两个条件同时满足,如果notify的时候Predicate返回…...

企业打造VR虚拟展厅,开启商务洽谈新时代!
现代化数字营销中,企业做了虚拟线上展厅和不做虚拟展厅的对比是很明显的,VR虚拟展厅让企业产品、企业环境、企业实力的展示更加真实、直观。虚拟展厅是一种在线展示企业形象和品牌的新型方式,随着VR技术的发展,虚拟展厅正在逐步取…...

linux部署gitlab
1. 配置yum源: vim /etc/yum.repos.d/gitlab-ce.repo [gitlab-ce] nameGitlab CE Repository baseurlhttps://mirrors.tuna.tsinghua.edu.cn/gitlab-ce/yum/el$releasever/ gpgcheck0 enabled1 2. 更新本地缓存 sudo yum install -y gitlab-ce 3. 安装相关依赖 yum …...

c++_learning-基础部分
文章目录 基础认识:语言特性(面向对象编程):c的类(相当于c中的结构体):三大特性:c包含四种编程范式:优缺点: c程序编译的过程:预处理->编译&am…...

支持PC端、手机端、数据大屏端的Spring Cloud智慧工地云平台源码
技术架构:微服务JavaSpring Cloud VueUniApp MySql 智慧建筑工地云平台主要利用大数据、物联网等技术,整合工地信息、材料信息、工程进度等,实现对建筑项目的全程管理。它可以实现实时监测和控制,有效解决施工中的问题,…...

给cmd控制台程序 套壳 美化
给cmd控制台程序套壳美化,可以获取程序的标准输出和报错信息。 # _*_ coding: utf-8 _*_ """ 控制台程序启动器,杜绝黑窗口。 Time: 2023/10/18 15:28 Author: Jyun Version: V 0.1 File: main.py Blog: https://ctrlcv.…...
【系统架构设计】架构核心知识: 1 构件和中间件
目录 一 构件 1 构件的特性 2 构件、对象和模块的对比 3 构件的复用...

idea大量爆红问题解决
问题描述 在学习和工作中,idea是程序员不可缺少的一个工具,但是突然在有些时候就会出现大量爆红的问题,发现无法跳转,无论是关机重启或者是替换root都无法解决 就是如上所展示的问题,但是程序依然可以启动。 问题解决…...

手游刚开服就被攻击怎么办?如何防御DDoS?
开服初期是手游最脆弱的阶段,极易成为DDoS攻击的目标。一旦遭遇攻击,可能导致服务器瘫痪、玩家流失,甚至造成巨大经济损失。本文为开发者提供一套简洁有效的应急与防御方案,帮助快速应对并构建长期防护体系。 一、遭遇攻击的紧急应…...

(十)学生端搭建
本次旨在将之前的已完成的部分功能进行拼装到学生端,同时完善学生端的构建。本次工作主要包括: 1.学生端整体界面布局 2.模拟考场与部分个人画像流程的串联 3.整体学生端逻辑 一、学生端 在主界面可以选择自己的用户角色 选择学生则进入学生登录界面…...

理解 MCP 工作流:使用 Ollama 和 LangChain 构建本地 MCP 客户端
🌟 什么是 MCP? 模型控制协议 (MCP) 是一种创新的协议,旨在无缝连接 AI 模型与应用程序。 MCP 是一个开源协议,它标准化了我们的 LLM 应用程序连接所需工具和数据源并与之协作的方式。 可以把它想象成你的 AI 模型 和想要使用它…...
基于matlab策略迭代和值迭代法的动态规划
经典的基于策略迭代和值迭代法的动态规划matlab代码,实现机器人的最优运输 Dynamic-Programming-master/Environment.pdf , 104724 Dynamic-Programming-master/README.md , 506 Dynamic-Programming-master/generalizedPolicyIteration.m , 1970 Dynamic-Programm…...
高效线程安全的单例模式:Python 中的懒加载与自定义初始化参数
高效线程安全的单例模式:Python 中的懒加载与自定义初始化参数 在软件开发中,单例模式(Singleton Pattern)是一种常见的设计模式,确保一个类仅有一个实例,并提供一个全局访问点。在多线程环境下,实现单例模式时需要注意线程安全问题,以防止多个线程同时创建实例,导致…...

算法:模拟
1.替换所有的问号 1576. 替换所有的问号 - 力扣(LeetCode) 遍历字符串:通过外层循环逐一检查每个字符。遇到 ? 时处理: 内层循环遍历小写字母(a 到 z)。对每个字母检查是否满足: 与…...
SQL慢可能是触发了ring buffer
简介 最近在进行 postgresql 性能排查的时候,发现 PG 在某一个时间并行执行的 SQL 变得特别慢。最后通过监控监观察到并行发起得时间 buffers_alloc 就急速上升,且低水位伴随在整个慢 SQL,一直是 buferIO 的等待事件,此时也没有其他会话的争抢。SQL 虽然不是高效 SQL ,但…...

华为OD机考-机房布局
import java.util.*;public class DemoTest5 {public static void main(String[] args) {Scanner in new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别while (in.hasNextLine()) { // 注意 while 处理多个 caseSystem.out.println(solve(in.nextLine()));}}priv…...

C++ 设计模式 《小明的奶茶加料风波》
👨🎓 模式名称:装饰器模式(Decorator Pattern) 👦 小明最近上线了校园奶茶配送功能,业务火爆,大家都在加料: 有的同学要加波霸 🟤,有的要加椰果…...