2.string函数
find:某子串的起始位(0开始),函数的第二个参数使用代表从该位开始的后缀
substr:1) x开始的连续y位
2) x开始的后缀
#include<bits/stdc++.h>
using namespace std;
int main(){
string s1="abcdef";
string s2="de";
//find
//返回位置 0起点
int ans=s1.find(s2);
cout<<ans<<"\n";
//substr 1
//x位开始的连续y位
cout<<s1.substr(0,3)<<"\n";
//substr 2
//x开始的后缀
cout<<s1.substr(1)<<"\n";
return 0;
}
string::npos 常数,作用类似于EOF,可以表示find函数未找到
getline(cin.a)输入一整行
tolower,toupper是string单个字符转换的函数
e.g:luogu 1308 统计单词数
#include<bits/stdc++.h>
using namespace std;
string a,b;
int main(){
getline(cin,a);
getline(cin,b);
for(int i=0;i<a.length();i++)
a[i]=tolower(a[i]);
for(int i=0;i<b.length();i++)
b[i]=tolower(b[i]);
a=' '+a+' ';
b=' '+b+' ';
if(b.find(a)==string::npos) printf("-1\n");
else{
int k=b.find(a),ans=0;
int k1=b.find(a);
while(k1!=string::npos){
++ans;k1=b.find(a,k1+1);}
printf("%d %d\n",ans,k);}
return 0;
}
来源:https://www.cnblogs.com/asdic/p/9526760.html