天天看點

C字元串和C++中string的差別 &&&&C++中int型與string型互相轉換 C++中int型與string型互相轉換

在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