需要掌握的操作:(參考-標準C++中的string類的用法總結)
一、string類的構造函數:
string(const char *s); //用c字符串s初始化
string(int n,char c); //用n個字符c初始化
此外,string類還支持默認構造函數和複製構造函數
例子:string s1="Nick";
string s2("Smith");
char a[]="nick";
string s3=s1;
string s4(a);//感覺C++中的string好強大,完全兼容C—style的字符串
二、string類的輸入輸出操作:
(重載運算符operator>>用於輸入,同樣重載運算符operator<<用於輸出操作)
getline(istream &in,string &s);用於從輸入流in中讀取字符串到s中,以換行符'\n'分開例子:getline(cin,s3);
三、string類的字符操作:
operator[]和at()均返回當前字符串中第n個字符的位置,但at函數提供範圍檢查,當越界時會拋出out_of_range異常,下標運算符[]不提供檢查訪問。例子 char c=s1[1]
四、string的符號操作:
運算符">","<",">=","<=","!=","=="均被重載用於字符串的比較;
string &operator+=(const string &s);//把字符串s連接到當前字符串的結尾
五、string的子串和查找:
字串:
string substr(int pos = 0,int n = npos) const;//返回pos開始的n個字符組成的字符串
例子 string s5=s3.substr(1,3);//從pos=1開始的三個字符
string類的查找函數:
int find(char c, int pos = 0) const;//從pos開始查找字符c在當前字符串的位置
int find(const char *s, int pos = 0) const;//從pos開始查找字符串s在當前串中的位置
例子 cout<<s3.find("th")<<endl;//返回7
總結:操作
#include<iostream>
#include<string>
using namespace std;
int main()
{
string s1="Nick";
string s2("Smith");
char a[]="nick";
string s3=s1;
string s4(a);
//getline(cin,s3);
s3.append(s2);
cout<<s3<<endl;//s3=nicksimth
//s3.swap(s1);
string s5=s3.substr(1,3);//從pos=1開始的三個字符
cout<<s5<<endl;
cout<<s3.find("th")<<endl;//輸出7
return 0;
}
程序題目:
一、字符串倒置
void stringReverse(string &s)
{
int len=s.length();
char c;
for (int i=0;i<len/2;++i)
{
c=s[i];
s[i]=s[len-1-i];
s[len-1-i]=c;
}
}
二、一句話按照單詞倒置 例如"i come from nanjing."輸出結果爲"nanjing. come from i"。
#include<iostream>
#include<string>
#include<vector>
using namespace std;
void stringReverse(string &s)
{
int len=s.length();
char c;
for (int i=0;i<len/2;++i)
{
c=s[i];
s[i]=s[len-1-i];
s[len-1-i]=c;
}
}
void stringReversePart(int p1,int p2,string &s)//本質是頭尾顛倒互換,找準頭尾字符串的位置
{
if (p1>=p2)
{
return;
}
int len=p2-p1+1;
char c;
for (int i=p1,cout=0;i<p1+len/2;++i,++cout)
{
c=s[i];
s[i]=s[p1+len-1-cout];//最後一個字符的位置是s[p1+len-1]
s[p1+len-1-cout]=c;
}
}
int main()
{
string s="wang qian.";
string r="rong";
string out;
int len=s.length();
cout<<"The original name is:"<<s<<endl;
stringReverse(s);
cout<<"After reverse:"<<s<<endl;
//stringReversePart(1,2,r);
int i=0;
int begin=0;
int end=0;
char c;
while (i<len)
{
while (i<len&&s[i]!=' ') //注意這個順序
{
++i;
end++;
}
++i;
end--;
while (end>begin)
{
c=s[begin];
s[begin]=s[end];
s[end]=c;
begin++;
end--;
}
begin=i;
end=i;
}
cout<<"After reverse by word:"<<s<<endl;
return 0;
}
結果輸出: