在C++中則把字元串封裝成了一種資料類型string,可以直接聲明變量并進行指派等字元串操作。以下是C字元串和C++中string的差別:
C字元串 | string對象(C++) | |
所需的頭檔案名稱 | <string>或<string.h> | |
需要頭檔案 原因 | 為了使用字元串函數 | 為了使用string類 |
聲明 方式 | char name[20]; | string name; |
初始化方式 | char name[20]="nihao"; | string name = "nihao"; |
必須聲明字元串長度麼? | 是 | 否 |
使用一個null字元麼? | ||
字元串指派 的實作方式 | strcpy(name,"John"); | name = "John"; |
優點 | 更快 | 更易于使用,優選方案 |
可以賦一個比現有字元更長的字元串麼? | 不能 | 可以 |
C++常用字元串函數
char s1[]="I am a student";
char s2[20]="teacher";
char s3[]="student";
int result;
char s4[20],*p;
(1)串長度 int strlen(char *str)
cout<<strlen(s1)<<endl; 輸出14
cout<<strlen(s2)<<endl; 輸出7
(2)串拷貝 char *strcpy(char *str1,char *str2)
strcpy(s4,s2); //s4為"teacher"
(3)串連接配接 char *strcat(char *str1,char*str2)
strcat(s2,s3); //s2為"teacherstudent"
(4)串比較 int strcmp(char *str1,char *str) //比較的是對應字元的ASCII碼值,如果str1>str2,傳回1
result=strcmp(s2,s3); //result>0
result=strcmp(s2,s2); //result=0
result=strcmp(s3,s2); //result<0
(5)串定位 char *strchr(char *str,char ch)
p=strchr(s1,'s'); //找到傳回字元在字串中的位置,否則傳回-1
strcpy(p,s2); //s1為"I am a teacher"
(6)在一個串中查找是否存在和另一個串相等的子串
(7)截取子串形成一個新串
字元串的輸入
(1)方法一:使用輸入操符來填充一個C字元串變量
例如:
char a[80];
cin>>a;
注:以這種方式來讀取C字元串時,會忽略最初的空白字元(空格、制表符和換行符),而且輸入會在下一個空格或者換行符處停止。
(2)方法二:使用預定義函數getline擷取整行輸入(包括空格)
getline函數有兩個參數:第一個參數用于接收輸入的C字元串變量;第二個參數用于規定getline最多能接收的字元個數。
例如:
cin.getline(a,80);
當遇到行結束的時候,輸入才會停止。
C++ string類的輸入
(1)方法一:和C字元串輸入的方法一相同。
(2)方法二:使用getline函數。
string a;
getline(cin,a);
string對象和C字元串之間的轉換
可以将C字元串存儲在string類型的變量中,例如:
char a[] = "nihao";
string b;
b=a;
但string對象不能自動的轉換為C字元串,需要進行顯式的類型轉換,需要用到string類的成員函數c_str().
strcpy(a,b.c_str());
字元串到數字的轉換
atoi函數擷取一個C字元串參數,傳回對應的int值。如果參數不與一個int值對應,atoi就會傳回0。atoi函數在檔案為cstdlib的庫中。如果數字太大,不能轉換成int類型的值,可以使用atol将字元串轉換為long類型的值。
atoi("1234"); //傳回整數1234
atoi("#123"); //傳回0
練習的題目:
//題目描述
//
//給定n個字元串,請對n個字元串按照字典序排列。
//輸入描述 :
//輸入第一行為一個正整數n(1≤n≤1000), 下面n行為n個字元串(字元串長度≤100), 字元串中隻含有大小寫字母。
//
//
//輸出描述 :
//資料輸出n行,輸出結果為按照字典序排列的字元串。
//本題的考察很基礎,但是有一些細節問題需要注意,在C語言中應注意C語言的所有字元串的本質是以空字元'\0'結束的字元數組,
//是以在C語言中對于字元串的比較不能使用> < == 這些正常的關系運算符,而要使用C語言标準庫函數中的strcmp函數對字元串進行比較,
//比較的原則就是字典順序,在C++中,string類對> < == 這些運算符進行了重載,可以直接用來比較字元串,比較的原則依然是字典順序。
//剩下的就是考察排序方法,常用的冒泡排序、選擇排序等等都可以實作,但是借助STL更友善
#include<iostream>
using namespace std;
#include<vector>
#include<string>
#include<algorithm>
int main()
{
int num;
while (cin>>num)
{
vector<string> ve;
string temp;
while (num--)
{
//scanf("%s",temp); //getline(cin,a);
//以前不是看的大量輸入時用scanf ,printf代替cin ,cout嗎??這裡不行啊
cin >> temp;
ve.push_back(temp);
}
sort(ve.begin(),ve.end());
for (auto it=ve.begin(); it!= ve.end(); it++)
{
//printf("%s\n", *it); //printf("%s", s.c_str()); //不推薦
cout << *it << endl;
}
}
return 0;
}
C++中int型與string型互相轉換
本以為這麼多年C#經驗,學個C++沒多難,現在發現錯了。C++真TM難。
今天遇到int轉string絆了半天,方法很多,不知道為什麼搞那麼複雜,
我隻挑最簡單易懂的,管他效率不效率的。
int轉string
int n = 0;
std::stringstream ss;
std::string str;
ss<<n;
ss>>str;
string轉int
std::string str = "123";
int n = atoi(str.c_str());
C/C++基本文法學習
STL
C++ primer