PAT-甲级刷题笔记和总结
本帖主要记录一些自己在刷题过程中的一些笔记,包括:
1、常用的函数
2、STL中常用方法
3、常见错误
4、其他常用方法
5、刷题过程中的常见算法:https://www.cnblogs.com/Mered1th/category/1403573.html
一、常用函数
头文件 #include<cctype>
isalpha 字母(包括大写小写)
islower (小写字母)
isupper (大写字母)
isalnum(字母大写小写+数字)
isblank(space和\t)
isspace(space、\t、\r、\n)
char t=tolower(c)将字符转换为小写字符赋值给t
头文件 #include<stdlib.h>
绝对值函数 abs()
substr()函数:作用是截取某个字符串中的子串
string s; getline(cin,s);//输入 ) //表示从下标4开始一直到结束 ,) //表示从下标5开始,3个字符
如果是char s[len], 输入要改为cin.getline(s,len)
string s; getline(cin,s); ]; cin.getline(str,);
strcmp()函数:字符串比较函数,注意返回值
strcmp(str1,str2);
若str1=str2,则返回零; 若str1<str2,则返回负数; 若str1>str2,则返回正数。
这个大部分情况下可用String代替。
取整函数:
向上取整直接可用+0.5
ceil(x)返回不小于x的最小整数值(然后转换为double型)。
floor(x)返回不大于x的最大整数值。
round(x)返回x的四舍五入整数值。
find和count的区别
count函数的功能是:统计容器中等于value元素的个数。先看一下函数的参数:
count(first,last,value);
first是容器的首迭代器,last是容器的末迭代器,value是询问的元素。
如果有返回1,无则返回0。返回值只能是1或0
而find()函数是返回其元素的位置(迭代器)
sprintf、sscanf用法
//sscanf的作用:把字符数组str中的内容以"%d"的格式写到n中 sscanf(str,"%d",&n); //sprintf的作用:把n以"%d"的格式写到str字符数组中 sprintf(str,") //str必须为数组名,不能是string类
stoi、stod函数(仅C++11支持):
//作用:分别将字符串转换为int或double型
//to_string函数:
); //将123转换为字符串
//c_str()函数:返回字符串首字符地址
//string类s1输出时可以printf("%s",s1.c_str());
二、STL中常用方法
vector初始化:
vector<)//容量为n,初始值为1
vector容器的去重unique函数:
利用unique函数,unique()作用是将不重复的元素往前移(将重复元素往后移动),返回值是重复元素的第一个位置。
先排序,去重配合erase函数。
ans.erase(unique(ans.begin,ans.end),ans.end) //用unique前先排序
vector的erase与insert要用迭代器,string的erase和insert无须迭代器。
s.insert(0,4-s.length(),'0'); 在0的位置插入4-s.length()个'0'
s.find返回的是下标的值,如果没有,用 “==string::npos”
lower_bound(first,last,val); //第一个值大于等于val的元素的位置 ,-); //第一个值大于val的元素的位置
函数返回的是位置! 如果要变成下标需要在后面减起始地址a
三、常见错误
常见错误:
1、段错误:大部分是因越界、非法访存引起的
2、浮点错误:除数或余数为0
3、注意输出的格式和单复数。
四、其他
C++构造函数写法
class Complex{
double real, imag;
Complex(); //第二个参数的默认值为0
};
Complex::Complex(double r,double i){
real = r;
imag = i;
}
实例:结构体Point用于存放平面点的坐标x,y
struct Point{
int x,y;
Point(){};
Point(int _x,int _y){
x=_x;
y=_y;
}
};
结构体内重载小于号 A1129 Recommendation System
struct node {
int value, cnt;
bool operator < (const node &a) const {
if (cnt != a.cnt){
return cnt > a.cnt;
}
else return value < a.value;
}
};//将node按照cnt排序,如果cnt相等就按value排序
完全二叉树的静态存储:
起始编号为0:index*2+1, index*2+2
起始编号为1,index*2,index*2+1
bool cmp(node a,node b){
if(a.flag==false||b.flag==false){
return a.flag>b.flag; //这样无效节点会排在后面
}
else return a.value<b.value;
}
字符串hash映射:

.png)
3、有数字,增加进制数。举例:

PAT-甲级刷题笔记和总结的更多相关文章
- 《Data Structures and Algorithm Analysis in C》学习与刷题笔记
<Data Structures and Algorithm Analysis in C>学习与刷题笔记 为什么要学习DSAAC? 某个月黑风高的夜晚,下班的我走在黯淡无光.冷清无人的冲之 ...
- Python 刷题笔记
Python 刷题笔记 本文记录了我在使用python刷题的时候遇到的知识点. 目录 Python 刷题笔记 选择.填空题 基本输入输出 sys.stdin 与input 运行脚本时传入参数 Pyth ...
- PTA刷题笔记
PTA刷题记录 仓库地址: https://github.com/Haorical/Code/tree/master/PTA/GPLT 两周之内刷完GPLT L2和L3的题,持续更新,包括AK代码,坑 ...
- PAT甲级 排序题_C++题解
排序题 PAT (Advanced Level) Practice 排序题 目录 <算法笔记> 6.9.6 sort()用法 <算法笔记> 4.1 排序题步骤 1012 The ...
- 《剑指offer》刷题笔记
简介 此笔记为我在 leetcode 上的<剑指offer>专题刷题时的笔记整理. 在刷题时我尝试了 leetcode 上热门题解中的多种方法,这些不同方法的实现都列在了笔记中. leet ...
- 18.9.10 LeetCode刷题笔记
本人算法还是比较菜的,因此大部分在刷基础题,高手勿喷 选择Python进行刷题,因为坑少,所以不太想用CPP: 1.买股票的最佳时期2 给定一个数组,它的第 i 个元素是一支给定股票第 i 天的价格. ...
- LeetCode刷题笔记和想法(C++)
主要用于记录在LeetCode刷题的过程中学习到的一些思想和自己的想法,希望通过leetcode提升自己的编程素养 :p 高效leetcode刷题小诀窍(这只是目前对我自己而言的小方法,之后会根据自己 ...
- LeetCode刷题笔记 - 12. 整数转罗马数字
学好算法很重要,然后要学好算法,大量的练习是必不可少的,LeetCode是我经常去的一个刷题网站,上面的题目非常详细,各个标签的题目都有,可以整体练习,本公众号后续会带大家做一做上面的算法题. 官方链 ...
- 1080 Graduate Admission——PAT甲级真题
1080 Graduate Admission--PAT甲级练习题 It is said that in 2013, there were about 100 graduate schools rea ...
随机推荐
- 在Emacs中使用GNU Global
背景 在我平时用Emacs编写C代码时,经常需要进行代码的跳转,主要需求为函数定义的跳转,某个具体函数的调用查找,某个结构体的定义跳转以及结构体中具体某一项的跳转等,GNU Global就能完全满足我 ...
- Redis安装和主要功能简介
Redis安装和主要功能简介 Redis(https://redis.io/), 是一个内存中的数据结构存储系统,它可以用作数据库.缓存和消息中间件. 安装Redis 我很少在开发机中直接装各种数 ...
- oracle在进行跨库访问时,采用dblink实现
首先了解下环境:在tnsnames.ora中配置两个数据库别名:test1/test1@11orcl1.tets2/tets2@12orlc2,在orcl1中创建database link来访问orc ...
- M端计算rem方法
(function(){var a=document.documentElement.clientWidth||document.body.clientWidth;if(a>460){a=460 ...
- 获取的时候报cannot find package "golang.org /x/net/context",编译也报错误
gitclone 这个https://github.com/golang/net.git ,编译通过了. 创建了相应的golang.org/x/ 路径, 然后将克隆的目录 放回golang.org/ ...
- /proc/sys/vm/drop_caches 清理缓存
1. 使用方法 /proc/sys/vm/drop_caches默认是0 # echo 1 > /proc/sys/vm/drop_caches; free pagecache, use# ec ...
- cookie、session的自我介绍
Cookie是什么? cookie说的直白点就是保存在用户浏览器端 的一个键值对,举个例子,你现在登录了京东商城,你把浏览器关闭之后,你再打开京东,你还是可以对你的账户继续操作,已经购买的商品,订单都 ...
- priority_queue
priority_queue<int> p;//最大值优先,是大顶堆一种简写方式 priority_queue<int,vector<int>,greater<in ...
- MQ中间件选型
如果Java项目,数据量不大,用ActiveMQ,相对简单.支持JMS. 如果对性能.可靠性有一定要求,用RabbitMQ. 如果对性能有很高要求,甚至可牺牲一些可靠性,选kakfa. 在当前大数据时 ...
- 怎样在两小时内搞定 OpenStack 部署?(转)
怎样在两小时内搞定 OpenStack 部署? OpenStack的安装是一个难题,组件众多,非常麻烦.如果手工部署OpenStack,可能需要好几天,使用RDO,就是几个命令,再加一两个小时的等待. ...