PAT乙级(CPP基础STL)

万能头,库

#include<bits/stdc++.h>

string数组

//string的初始化
string s="abc";
string(6,'A');
//string取子串(起始位置,长度)
string s="Hello World!"; 
cout << s.substr(6) << endl; //从第6位开始取字符,即从W开始
cout << s.substr(6,2) << endl; //从第6位开始取2个字符
s.replace(2,5,"XXXX");//string替换(起始位置,长度,替换字符)
s.erase(0,2); //string的删除(起始位置,长度)*也可以用replace实现
s.c_str();//string转化成字符串

vector动态数组

vector<int> data;
data.push_back(1);
cout << data.size();
vector<int> v(10);//定义长度为10的int数组,默认10个元素均为0vector<int> v;
v.resize(8);//先定义,后将长度设置为8,默认元素都为0vector<int> v(100,9);//定义+初始化,元素值均为9
for(int i=0; i < v.size(); i++)//下标遍历for(vector<int>::iterator i = v.begin(); i != v.end(); i++) //迭代器遍历for(auto i=A.begin(); i!=A.end(); i++)cout << *i << endl;

清空数组 

s.clear()

set集合(要求有序)

set<int> s
s.insert(1);//查询集合内的元素
if(s.find(5) != s.end()){cout << "yes" << endl;
}

set 具有天然的排序与去重功能,结构体不是基本类型(基本类型有默认的排序准则),因此需要重载 < 运算符。(相当于给自定义类型一个排序准则)。bool operator < (const HolePos & a)const ;运算符重载必须是const。

#include<iostream>
#include<set>
#include<string>
using namespace std;struct stu {string name;string id;int sco;bool operator < (const stu & a)const {return id < a.id;}
};
int main()
{set<stu> s;s.insert(stu{ "214820413","xyq",50 });s.insert(stu{ "214820414","yjw",70 });for (auto i = s.begin();i != s.end();i++){cout << i->name << " " << i->id << " " << i->sco << endl;}return 0;
}

map键值对,映射 <key,value>

#include<iostream>
#include<map>
using namespace std;int main()
{map<string, int>m = {{"id1",60},{"id2",70}};cout << m["id1"] << endl;cout << m["id2"] << endl;return 0;
}

map遍历 

for (auto i = m.begin(); i != m.end();i++){cout << i->first << " " << i->second << endl;}

sort函数

#include<algorithm>
int A[] = { 5,2,6,7,4,1,3 };
sort(A, A+7);
for (int i = 0; i < 7; i++)cout << A[i] << " ";
vector<int> A;
sort(A.begin(),A.end());

cmp函数调用 

#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;struct stu {int score;string id;
};bool cmp(stu a, stu b)
{if (a.score == b.score)return a.id < b.id;return a.score < b.score;
}
int main()
{vector<stu> L;L.push_back(stu{ 50,"ccc" });L.push_back(stu{ 50,"bbb" });L.push_back(stu{ 60,"aaa" });sort(L.begin(), L.end(),cmp);for (int i = 0; i < L.size(); i++)cout << L[i].id << " " << L[i].score << endl;return 0;
}

折半查找lower_bound和upper_bound,注意排序

#include<iostream>
#include<algorithm>
using namespace std;int main() {int num[6] = { 1,2,4,7,15,34 };sort(num, num + 6);                           //按从小到大排序 int pos1 = lower_bound(num, num + 6, 7) - num;    //返回数组中第一个大于或等于被查数的值 int pos2 = upper_bound(num, num + 6, 7) - num;    //返回数组中第一个大于被查数的值cout << pos1 << " " << num[pos1] << endl;cout << pos2 << " " << num[pos2] << endl;return 0;
}

转换 to_string, stoi & stod

string s1 = to_string(123);//把数字转化为string
stoi("123");//把string转换为int

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

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

相关文章

【新手解答7】深入探索 C 语言:代码缩进 + 变量作用域、静态变量 + 变量名和函数名重名

C语言的相关问题解答 写在最前面问题一&#xff1a;代码缩进问题二&#xff1a;C语言中的变量作用域变量作用域静态变量总结 问题三&#xff1a;变量名和函数名重名相关解析变量 sumC 语言中&#xff0c;sum 并不是一个内置的函数名或保留字变量名和函数名重名&#xff1f;总结…

Oracle中mybatis批量更新报错ORA-00933:SQL命令未正确结束

项目场景&#xff1a; 最近在开发项目的过程中遇见了这个问题&#xff1a;Oracle中批量更新的时候报错 ORA-00933&#xff1a;SQL命令未正确结束 问题描述 mybatis批量更新报错ORA-00933&#xff1a;SQL命令未正确结束 <foreach item"item" index"index&q…

【TinyALSA全解析(三)】tinyplay、tincap、pcm_open源码解析

tinyplay、tincap、pcm_open源码解析 一、本文的目的二、tinyplay.c源码分析三、tinycap.c源码分析四、pcm.c如何调度到Linux Kernel4.1 pcm_open解析4.1.1 pcm_open的主要流程4.1.2 流程说明4.1.3 调用方法 4.2 pcm_write解析 /*********************************************…

图解系列--HTTPS,认证

确保 Web 安全的HTTPS 1.HTTP 的缺点 1.1.通信使用明文可能会被窃听 加密处理防止被窃听 加密的对象可以有这么几个。 (1).通信的加密 HTTP 协议中没有加密机制&#xff0c;但可以通过和 SSL&#xff08;Secure Socket Layer&#xff0c;安全套接层&#xff09;或TLS&#xff…

android 特殊权限处理

运行时权限之特殊权限android.permission.SYSTEM_ALERT_WINDOW 以下为特殊权限的一种申请写法(android.permission.SYSTEM_ALERT_WINDOW) 在做双屏异显功能时,需要使用到Presentation, 使用Presentation需要android.permission.SYSTEM_ALERT_WINDOW权限, 于是就使用谷歌的权限框…

猜-MISC-bugku-解题步骤

——CTF解题专栏—— 题目信息&#xff1a; 题目&#xff1a;猜 作者&#xff1a;harry 提示&#xff1a; 解题附件&#xff1a;flag格式key{图中人物名字全拼} 解题思路&#xff1a; 这......头都没有&#xff0c;让我guess&#xff1f;&#xff1f;&#xff1f;详细信息看…

NASM安装和结合nodepad++进行编译的过程

mov ax,0x30 mov bx,0xc0 add ax,bx times 502 db 0 db 0x55 db 0xAA nasm安装地址: https://www.nasm.us/ 下载exe安装 在命令行提示符输入nasm编译命令 nasm exam.asm -f bin -o exam.bin 此时输入回车将会执行编译过程。 1&#xff0c;启动NotePad&#xff0c;在菜单上选…

web前端tips:js继承——寄生组合式继承

上篇文章给大家分享了 js继承中的 寄生式继承 web前端tips&#xff1a;js继承——寄生式继承 今天给大家分享一下 js 继承中的 寄生组合式继承 寄生组合式继承 寄生组合式继承是一种结合了寄生式继承和组合式继承的方式&#xff0c;它的目标是减少组合式继承中多余的调用父…

【Java 并发编程】进程线程、lock、设计模式、线程池...

博主&#xff1a;_LJaXi Or 東方幻想郷 专栏&#xff1a; Java | 从入门到入坟 Java 并发编程 并发编程多线程的入门类和接口线程组和线程优先级线程的状态及主要转化方法线程间的通信重排序和 happens-beforevolatilesynchronized 与锁CAS 与原子操作AQS计划任务Stream 并行计…

开放式耳机哪个品牌好用?超好用的耳机推荐,新手小白必看

在当今数不胜数的音频品牌中&#xff0c;寻找一款优秀的开放式耳机成为了许多音乐爱好者和新手小白的共同关注点&#xff0c;开放式耳机以其通透的音质和舒适的佩戴感受受到了广泛好评&#xff0c;但市场上的选择却让人眼花缭乱&#xff0c; 为了帮助新手小白在这个耳机的海洋…

从零开始:打造自己的抖音核销工具小程序

对于商家而言&#xff0c;如何高效核销活动中的抖音优惠券成为一项挑战。在这篇文章中&#xff0c;我们将探讨如何从零开始&#xff0c;打造一个个性化、高效的抖音核销工具小程序。 第一步&#xff1a;明确需求和目标 在动手之前&#xff0c;我们需要明确自己的需求和目标。…

ICC2:使用analyze_lib_cell_placement检查lib cell的pass rate

我正在「拾陆楼」和朋友们讨论有趣的话题,你⼀起来吧? 拾陆楼知识星球入口 在place之前需要使analyze_lib_cell_placement命令去检查lib cell在当前的site row/power plan/legalize设置的环境下能够正常place和legalize。 下面分享一个脚本去报告pass rate低于2%的lib cell…

【Amazon】安装Cloudwatch代理监控EC2

文章目录 一、实验概要二、实验操作步骤2.1 创建 CloudWatch 代理运行角色2.2 安装 CloudWatch 代理软件包2.3 使用 CloudWatch代理收集指标2.4 CloudWatch指标收集确认 三、参考链接 一、实验概要 使用 CloudWatch 代理从 Amazon EC2 实例和本地服务器中收集指标、日志和跟踪信…

在SpringBoot中使用定时任务注解实现简单的定时任务

定时任务&#xff0c;其实在我们开发过程中经常会碰到的一个场景&#xff0c;比如&#xff0c;我现在想要给某些用户定时的发送一些短信呀&#xff0c;邮件呀什么的&#xff0c;也可以用来定时的检查或者监测我们对一些参数的处理。玩的花的可以用来帮我我们进行网页签到&#…

前端:实现div元素选中与不可选中

默认情况下&#xff0c;div元素是可以选中的&#xff0c;但如果需要设置为不可被选中&#xff0c;可以设置为&#xff0c;如下&#xff1a; div {user-select: none; } 如果希望在某些情况下允许选择&#xff0c;可以在需要的地方覆盖这个样式。例如&#xff1a; div.allow…

AI模特换装的前端实现

本文作者为 360 奇舞团前端开发工程师 随着AI的火热发展&#xff0c;涌现了一些AI模特换装的前端工具&#xff08;比如weshop网站&#xff09;&#xff0c;他们是怎么实现的呢&#xff1f;使用了什么技术呢&#xff1f;下文我们就来探索一下其实现原理。 总体的实现流程如下&am…

笔记二十六、React中路由懒加载的扩展使用

26.1 在路由中配置懒加载 lazy routes/index.jsx 代码 import {Navigate} from "react-router-dom"; import Home from "../components/Home"; import About from "../components/About"; // import Classify from "../components/Home/c…

自动化测试框架搭建步骤教程

说起自动化测试&#xff0c;我想大家都会有个疑问&#xff0c;要不要做自动化测试&#xff1f; 自动化测试给我们带来的收益是否会超出在建设时所投入的成本&#xff0c;这个嘛别说是我&#xff0c;即便是高手也很难回答&#xff0c;自动化测试的初衷是美好的&#xff0c;而测试…

CAD精品Eyeshot Fem 2023.3.630 -2023-11-05 Crack

2023.3.630 更新25天前 分享 跟随还没有人关注 改进的 Brep.TransformBy() 方法修复了工具栏内存泄漏修复了 glTF 材质导出期间的异常改进了 glTF 材质金属粗糙度设置修复了渐进式绘图和剪辑平面的错误在 Workspace.UseShaders 属性设置器中添加了缺少的 RenderContext.MakeCur…

Linux基础操作一:连接Linux

1、连接方式 1.1、SSH连接 SSH是Secure Shell的缩写&#xff0c;用于加密远程连接和文件传输的协议。可以使用SSH连接到远程Linux服务器以及在本地访问Linux计算机。SSH连接可以用于执行命令或者上传或下载文件。 – 在Linux命令行中使用SSH连接&#xff1a;可以使用命令ssh…