1/13号笔记
输入输出
头文件<iostream>包括了scanf和printf的定义,无须再引用<cstdio>头文件。
代码
#include <iostream>
scanf("%d", &b);
printf("%d ", a[i]);
sort函数
以平均O( n ∗ l o g 2 n n*log_2^n n∗log2n)的时间复杂度得到递增的有序序列,可以对容器进行排序,也可以直接对数组进行排序。参数一般为2,也可以是3,第三个是对待排序容器的序列规则的定义。
头文件
#include <algorithm>
代码
数组: sort(a, a+4);
string: sort(up.begin(), up.end());
加比较规则的定义:
bool decrease(char i,char j) {
return i > j; // 递减
}
sort(chars, chars+4, decrease);
reverse函数
将数组或者容器的某个范围内元素逆转顺序。
头文件
#include <algorithm>
代码
reverse(a, a+4);
reverse(down.begin(), down.end());
to_string函数
将一个数字转成string类型,int直接转成string,小数点保持6位。
头文件
#include<string>
代码
int c = 123;
float a = 1.234;
float b = 1.23456789;
string a_str = to_string(a);
string b_str = to_string(b);
string c_str = to_string(c);
cout << a_str << endl << b_str << endl << c_str << endl;
return 0;
运行结果
C:\Users\15709\Desktop\PAT>g++ sample.cpp
C:\Users\15709\Desktop\PAT>a
1.234000
1.234568
123
stoi函数
将string转成数字,默认是十进制,后面可以加参数说明转换形式
头文件
#include <string>
代码
int a = stoi(str1), b = stoi(str2);
std::string str_dec = "2001, A Space Odyssey";
std::string str_hex = "40c3";
std::string str_bin = "-10010110001";
std::string str_auto = "0x7f";
std::string::size_type sz; // alias of size_t
int i_dec = std::stoi (str_dec,&sz);
int i_hex = std::stoi (str_hex,nullptr,16);
int i_bin = std::stoi (str_bin,nullptr,2);
int i_auto = std::stoi (str_auto,nullptr,0);
std::cout << str_dec << ": " << i_dec << " and [" << str_dec.substr(sz) << "]\n";
std::cout << str_hex << ": " << i_hex << '\n';
std::cout << str_bin << ": " << i_bin << '\n';
std::cout << str_auto << ": " << i_auto << '\n';
2001, A Space Odyssey: 2001 and [, A Space Odyssey]
40c3: 16579
-10010110001: -1201
0x7f: 127