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