1如何求一串字符串的实际字符数
#include<bits/stdc++.h>
using namespace std;
int main(){
string s;
getline(cin, s);
cout << s.size() << endl;
return 0;
}
2检查字符串中数字个数
#include<bits/stdc++.h>
using namespace std;
int main()
{
string a;
int cnt=0;
getline(cin,a);
int n=a.size();
for(int i=0;i<n;i++)
if(a[i]>='0'&&a[i]<='9')
cnt++;
cout<<cnt<<endl;
return 0;
}
用字符串读入,可以当作字符数组
getline函数没有返回值
3将输入的字符串中的字母每一个的acsII都增大1,
可以用string s + getline(cin, s)读入然后遍历字符串数组++,也可以用char c,scanf("%c",&ch)==1,每次读入就(ch+1-'A')%26+'A'
另外,小数除法需要有double或者1.0
4如何输出字符的acsII码
char ch;
while(scanf("%c",&ch) != 0){
cout << (int) ch;
}
5石头剪刀布模拟题
技巧:可以通过比较字符串长度输出结果。
输入可以使用cin,但是cin的读入不可以有空格(没空格的字符串就用cin输入),getline读到空格不停止,到回车才停止。
6字符串乘方
if(s[j]!=s[j%i])用这个判断每i个字符一个循环
7最长公共字符串后缀
首先通过字符串数组存储所有输入,然后反转所有字符串,再用sort排序,比较0号和n-1号的相同的部分,就是公共后缀的最大值
#include<bits/stdc++.h>
using namespace std;
int n;
string a[210];
int main(){
while(cin >> n)
{
if(n==0)
return 0;
for(int i = 0; i < n; i ++ )
cin >> a[i], reverse(a[i].begin() , a[i].end());
sort(a, a + n);
string v;
for(int i = 0; i < a[0].length(); i ++ ) {
if(a[0][i]==a[n-1][i]) v=a[0][i]+v;
else break;
}
cout << v << endl;
}
}
8字符串依次将第一位放到最后一位
string a;cin >> a;a += a; 新字符串必然是其子串
学会更多的string函数可以有效缩短代码量
e.g s.begin(),s.find,s.rfind,string::npo ……