记录我在刷力扣时遇到的一些知识点,持续更新中。
目录
(4)cin.getline(字符数组名,接收长度,结束符)
一、数组的初始化问题
我经常会用 int arr[5]={0}; 来初始化数组,但是这种方法只能适用于将所有值初始化为0,若是其他数值,则只会初始化arr[0]。
二、memset函数
这个函数我以前经常在用,但是一直是将数组初始化为0或1,也就没有出现问题,直到今天,我初始化为2的时候,提交错误,才让我真正了解了这个函数的用法。
#include<string.h>
void *memset(void *s, int ch, size_t n);//函数形式
函数功能:为指针变量s所指的前n个字节的内存单元填充给定的int型数值ch,它可以为任何数据进行初始化。换句话说,就是将数值ch以单个字节逐个拷贝的方式放到指针变量s所指的内存中去。 注意:只将数值ch的最低一个字节填充到内存。
例如:
memset(arr , 2 , sizeof(arr))
2的二进制表达为0000 0000 0000 0000 0000 0000 0000 0010
将其最后一个字节即0000 0010以单个字节逐个填充到数组arr的内存,则arr所有元素变为0000 0010 0000 0010 0000 0010 0000 0010 即33686018
若是不填充所有字节,如
memset(arr , 2 , 6)
同理 arr[0]=33686018 arr[1]=0000 0000 0000 0000 0000 0010 0000 0010 即514 (字节填充从低到高)
memset()还可以填充char类型数组,直接按地址填充。
三、vector的输出
大多数时候我用vector都是确定好长度n的,但是如果遇到没有确定n的情况下,每push_back或pop一个值,n都会改变,这时候需要用到迭代器。
每种容器都定义了自己的迭代器类型,例如vector:
vector<int>::iterator iter; //定义一个名为iter的迭代器
迭代器的初始化
vector<int> ivec;
vector<int>::iterator iter1=ivec.bengin(); //将迭代器iter1初始化为指向ivec容器的第一个元素
vector<int>::iterator iter2=ivec.end(); //将迭代器iter2初始化为指向ivec容器的最后一个元素的下一个位置
例如:
还可以用auto自动补全数据类型
四、从键盘读取数据
(1)cin
遇到空格、制表符、回车会立即终止输入
int main()
{
int a;
cin>>a;
cout<<a;
return 0;
}
//输入 12 56 98
//输出 12
需要输入不定长度的数据时,用while从键盘输入,用cin.get()判断结束
int main()
{
vector<int> arr;
int a;
while(cin>>a)
{
arr.push_back(a);
if(cin.get()=='\n')break;
}
return 0;
}
(2)getline(cin, inputLine);
接收一个字符串,可以接收空格并输出,需包含“#include<string>”
int main()
{
string str;
getline(cin,str);
cout<<str;
return 0;
}
//输入 hello world !
//输出 hello world !
(3)cin.get(字符数组名,接收长度,结束符)
其中结束符意味着遇到该符号结束字符串读取,默认为enter,读取的字符个数最多为(长度 - 1),因为最后一个为'\0'。
要注意的是,cin.get(字符数组名,接收长度,结束符)操作遇到结束符停止读取,但并不会将结束符从缓冲区丢弃。
int main()
{
char ch1, ch2[10];
cin.get(ch2, 7);//在不遇到结束符的情况下,最多可接收6个字符到ch2中,注意结束符为默认Enter
cin.get(ch1);//或ch1 = cin.get();
cout << ch2 << endl;
cout << ch1 << "\n" << (int)ch1 << endl;
return 0;
}
//输入 jilks
//输出 jilks
//
//
// 10
输入时第六个为换行,ch2结束读取为jilks,换行依然在缓存区,而ch1从缓存区读取到换行,再输出ch1,所以输出两个换行。
(4)cin.getline(字符数组名,接收长度,结束符)
其用法与cin.get(字符数组名,接收长度,结束符)极为类似。cin.get()当输入的字符串超长时,不会引起cin函数的错误,后面若有cin操作,会继续执行,只是直接从缓冲区中取数据。
但是cin.getline()当输入超长时,会引起cin函数的错误,后面的cin操作将不再执行。
可以读取空格
int main()
{
char ch1, ch2[8]; // 最多可接收7个,最后一个'\0'
cin.getline(ch2, 6);//在不遇到结束符的情况下,最多可接收5个字符到ch2中
for(auto i : ch2)cout << i << " ";
cout<<endl;
cout<<"now cin ch1"<<endl;
cin >> ch1;
cout << ch1 << "\n" << (int)ch1 << endl;
return 0;
}
/*
mn jkliu
m n j k
now cin ch1
0
*/
后面的cin>>ch1操作没有执行,程序直接执行结束。
(5)gets()
接收一串字符,可以读取空格,但是,gets()函数在读取字符串时,可以超过字符数组的容量
char ch[5];
gets(ch);
cout << ch << endl;
/*
mnbvgdu
mnbvgdu
*/
五、加速流,减少时间
在主函数之前声明即可。
int io=[](){
ios::sync_with_stdio(0);
cin.tie(0);
return 0;
}();
c++是兼容c的,c++中的输出流是cout,而c中是printf,我们可以发现c++中也是可以使用printf的,因为c++将输出流给绑定到一起了。使用sync_with_stdio(0);可以将cin,cout与scanf,printf解绑,不需要缓存,增加速度。
系统默认的是将cin和cout绑定在一起,每次使用“>>”的时候都会执行flush刷新流,这也会导致效率下降,这时候我们使用tie(0)来解除绑定,就可以加快效率。
六、substr()函数
头文件:#include<string>
原型:substr(size_type _Off = 0,size_type _Count = npos)
用法 : 被截取的原字符串.substr(开始位置, 截取长度)
返回值:string,包含s中从pos开始的len个字符的拷贝(pos的默认值是0,len的默认值是s.size() - pos,即不加参数会默认拷贝整个s)
int main()
{
string s="hello, csdn !";
string str1=s.substr(0,3);
string str2=s.substr(1,3);
string str3=s.substr(3,30);
cout<<str1<<'\n'<<str2<<'\n'<<str3;
return 0;
}
/*
hel
ell
lo, csdn !
*/