談談兩種標準庫類型---string和vector

来源:https://www.cnblogs.com/XNQC1314/archive/2018/01/03/8076240.html
-Advertisement-
Play Games

兩種最重要的標準庫 string和vector string和vector是兩種最重要的標準庫類型,string表示可變長的字元序列,vector存放的是某種給定類型對象的可變長序列。 一、標準庫類型string 1.定義和初始化string對象:初始化string對象的方式有 string s1 ...


兩種最重要的標準庫---string和vector

string和vector是兩種最重要的標準庫類型,string表示可變長的字元序列,vector存放的是某種給定類型對象的可變長序列。

一、標準庫類型string

  1.定義和初始化string對象:初始化string對象的方式有

    string s1   預設初始化,s1是一個空串   string s2(s1)   s2是s1的副本

    string s2=s1   等價於s2(s1),s2是s1的副本  

    string s3("value")  s3是字面值"value"的副本,除了字面值最後的那個空字元外

    string s3="value"  等價於s3("value"),s3是字面值"value"的副本  

    string s4(n,'c')  把s4初始化為由連續n個字元c組成的串

    如果使用等號(=)初始化一個變數,實際上執行的是拷貝初始化,編譯器把等號右側的初始值拷貝到心創建的對象中去。與之相反,如果不使用等號,則執行的是直接初始化。

  2.string對象上的操作

    os<<s  將s寫到輸出流os當中,返回os    is>>s  從is中讀取字元串賦給s,字元串以空白分隔,返回is

    getline(is,s)  從is中讀取一行賦給s,返回is    s.empty()  s為空返回true,否則返回false

    s.size()  返回s中字元的個數    s[n]  返回s中第n個字元的引用,位置n從0計起

    s1+s2   返回s1和s2連接後的結果   s1=s2   用s2的副本代替s1中原來的字元

    s1==s2  s1!=s2  如果s1和s2中所含的字元完全一樣,則他們相等;string對象的相等性判斷對字母的大小寫敏感

  讀取未知數量的string對象

 

#include <iostream>
#include <string> using namespace std; int main() { string word; while(cin>>word) cout<<word<<endl; return 0; }

 

    使用getline()讀取一整行:

         getline函數的參數是一個輸入流和一個string對象,函數從給定的輸入流中讀入內容,直到遇到換行符為止(註意換行符也被讀進來了),然後把所讀的

    內容存入到那個string對象中去(註意不存換行符)。

#include <iostream>
#include <string>
using namespace std;
int main()
{
   string line;    //每次讀入一整行,直到達文件末尾
   while(getline(cin,line))
     cout<<line<<endl;
   return 0;
}

    string的empty和size操作:

       empty函數根據string對象是否為空返回一個對應的布爾值,empty也是string的一個成員函數。

#include <iostream>
#include <string>
using namespace std;
int main()
{
   string line;
   while(getline(cin,line))   //每次讀入一整行,遇到空行直接跳過
     if(!line.empty())
       cout<<line<<endl;
   return 0;
}

      size函數返回string對象的長度(即string對象中字元的個數)

#include <iostream>
#include <string>
using namespace std;
int main()
{
   string line;
   //每次讀入一整行,輸出其中超過100個字元的行
   while(getline(cin,line))
     if(line.size()>100)
       cout<<line<<endl;
   return 0;
}

   處理string對象中的字元:使用基於範圍的for語句

        範圍for語句:這種語句遍歷給定序列中的每個元素並對序列中的每個值執行某種操作,

             for (declaration : expression)

                   statement

          其中,expression部分是一個對象,用於表示一個序列。declaration部分負責定義一個變數,該變數將被用於訪問序列中的基礎元素。每次迭代,

         declaration部分的變數會被初始化為expression的下一個元素值。

#include <iostream>
#include <string>
#include <ctype.h>
using namespace std;
int main()
{
    string s("hello world!!!");
    for (decltype(s.size()) index = 0;index != s.size() && !isspace(s[index]);++index)
        s[index] = toupper(s[index]);
    cout << s << endl;
    /*decltype(s.size()) punct_cnt = 0;
    for (auto c : s)
        if (ispunct(c))
            ++punct_cnt;
    cout << punct_cnt
        << " punctuation characters in "
        << s << endl;*/
    /*for (auto & c : s)
        c = toupper(c);
    cout << s << endl;*/
    getchar();
    return 0;
}

 二、標準庫類型vector

     1. 標準庫類型vector表示對象的集合,其中所有對象的類型都相同。集合中的每個對象都有一個與之對應的索引,索引用於訪問對象。因為vector容納著其他對象,

所以它也被稱作容器。

      vector能容納絕大多數類型的對象作為其元素,但是因為引用不是對象,所以不存在包含引用的vector。除此之外,其他大多數(非引用)內置類型和類類型都可

以構成vector對象,甚至組成vector的元素也可以是vector。

    2. 定義和初始化vector對象

    和任何一種類類型一樣,vector模板控制著定義和初始化向量的方法。

    vector<T> v1    v1是一個空vector,它潛在的元素是T類型的,執行預設初始化     vector<T> v2(v1)    v2中包含有v1所有元素的副本

    vector<T> v2=v1   等價於v2(v1),v2中包含有v1所有元素的副本   vector<T> v3(n,val)   v3包含了n個重覆的元素,每個元素的值都是val

    vector<T> v4(n)   v4包含了n個重覆地執行了值初始化的對象   vector<T> v5{a,b,c...}  v5包含了初始值個數的元素,每個元素被賦予相應的初始值

    vector<T> v5={a,b,c...}    等價於v5{a,b,c...}

   3. vector支持的操作

    v.empty()  如果v不含有任何元素,返回真;否則返回假     v.size()  返回v中元素的個數

    v.push_back(t)   向v的尾端添加一個值為t的元素   v[n]  返回v中第n個位置上元素的引用

    v1=v2  用v2中元素的拷貝替換v1中的元素   v1={a,b,c...}  用列表中元素的拷貝替換v1中的元素

    v1==v2  v1和v2相等當且僅當它們的元素數量相同且對應位置的元素值都相同    v1!=v2  

   4. 向vector對象中添加元素

#include <iostream>
#include <vector>
using namespace std;
int main()
{
    vector<int> v;
    int a;
    while (cin >> a ,a!=-1)
        v.push_back(a);
    for(auto i : v)
    cout << i << endl;
    system("pause");
    return 0;
}

  5. 使用迭代器

    使用迭代器可以訪問某個元素,迭代器也能從一個元素移動到另外一個元素。迭代器有有效和無效之分,這一點和指針差不多。有效的迭代器或者指向某個元素,或者

指向容器中尾元素的下一個位置;其他所有情況都屬於無效。這些類型都擁有名為begin和end的成員,其中begin成員負責返回指向第一個元素(或第一個字元)的迭代器。

end成員則負責返回指向容器(或string對象)“尾元素的下一個位置”的迭代器,該迭代器指示的是容器的一個本不存在的“尾後”元素。end成員返回的迭代器常被稱作尾後

迭代器或者簡稱為尾迭代器。特殊情況下如果容器為空,則begin和end返回的是同一個迭代器。

    標準容器迭代器的運算符:

       *iter   返回迭代器iter所指元素的引用     iter->mem  解引用iter並獲取該元素的名為mem的成員,等價於(*iter).mem

       ++iter  令iter指示容器中的下一個元素     --iter  令iter指示容器中的上一個元素

       iter1==iter2   iter1 != iter2   判斷兩個迭代器是否相等(不相等),如果兩個迭代器指示的是同一個元素或者它們是同一個容器的尾後迭代器,則相等;反之,不相等

#include <iostream>
#include <vector>
#include <string>
#include <ctype.h>
using namespace std;
int main()
{
    string s("some string");
    if (s.begin() != s.end())
    {
        auto it = s.begin();
        *it = toupper(*it);
    }
    cout << s << endl;
    system("pause");
    return 0;
}
#include <iostream>
#include <vector>
#include <string>
#include <ctype.h>
using namespace std;
int main()
{
   string s("some string");
   if (s.begin() != s.end())
    {
        for (auto it = s.begin();it != s.end() && !isspace(*it);++it)
            *it = toupper(*it);
    }
    cout << s << endl;
    system("pause");
    return 0;
}

     迭代器類型:擁有迭代器的標準庫類型使用iterator和const_iterator來表示迭代器的類型。const_iterator和常量指針差不多,能讀取但不能修改它所指的元素值。

相反,iterator的對象可讀可寫。如果vector對象或string對象是一個常量,只能使用const_iterator;如果vector對象或string對象不是常量,那麼既能使用iterator也能

使用const_iterator。

   begin和end運算符:begin和end返回的具體類型由對象是否是常量決定,如果對象是常量,begin和end返回const_iterator;如果對象不是常量,返回iterator。為了

便於得到const_iterator類型的返回值,引入了兩個新函數,分別是cbegin和cend,類似於begin和end,兩個新函數也分別返回指示容器第一個元素或最後元素下一個

位置的迭代器。不同的是,不論vector對象(或string對象)本身是否是常量,返回值都是const_iterator。

#include <iostream>
#include <vector>
#include <string>
#include <ctype.h>
using namespace std;
int main()
{
    string s("some string");
    if (s.begin() != s.end())
        for (auto it = s.cbegin();it != s.cend() && !s.empty();++it)
            cout << *it;
    cout << endl;
    system("pause");
    return 0;
}

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1. Python的函數 1.1 函數的定義 在Python中,函數是邏輯結構化和過程化的一種方法;是帶名字的、組織好的、可重覆使用的代碼塊,用於完成具體的任務。Python用def關鍵字來定義函數,然後用return關鍵字返回值,其語法格式如下: def 函數名稱([參數1],[參數2],..., ...
  • 資料庫連接池(DBCP和C3P0) 一.資料庫連接池的概念 資料庫連接池可以理解為是存放多個資料庫連接的集合。 作用;解決建立資料庫連接耗費很多資源和時間問題,提高性能 Java為資料庫連接池提供了公共的介面:javax.sql.DataSource,各個廠商需要讓自己的連接池實現這個介面。這樣應用 ...
  • 模板V層; $this->assign($arr);變數輸出到模板; $this->display("set"); $this->theme("blue")->display("set"); controller 中 $this->abc = "wo"; V層html文件中:$abc 賦值了 {$a ...
  • &: 如果兩邊的表達式有一個為false結果就是false,兩邊都是true,結果是true &&:與&不同的是,當左邊出現false是有區別,&不管左邊是真還是假,右邊都進行判斷, && 當左邊是false時,不在進行右邊的真假判斷,結果直接是false |: 兩邊有一個為true,結果是true ...
  • Java NIO 之 Buffer Java NIO (Non Blocking IO 或者 New IO)是一種非阻塞IO的實現。NIO通過Channel、Buffer、Selector幾個組件的協同實現提升IO效率的目的。而ByteBuffer是其中最基礎的一種Buffer實現。 阻塞 or 非 ...
  • 一.nullptr 示例: #include void foo(char * c){}void foo(int n){}int main(){foo(0);// foo(NULL); // ... ...
  • 1.Array & Arrays 與Collection & Collections區別 (1)Collection": 是一個介面,與其子類共同組成一個Collection集合框架; Collections: 是一個類,一個服務於集合的工具類, 提供一系列靜態方法實現對各種集合的搜索、排序、線程安 ...
  • 文章結尾有彩蛋 《學生成績管理系統》實習內容及要求 一、項目名稱:“學生成績管理系統”,包名是“班級名稱全拼”(例如計算171),Java文件名稱是“姓名全拼+班級號+學號”(例如計算171班的張三,學號為5號,則他的文件名稱為“zhangsan1705),其他類名稱為“類名+班級號+學號”(例如計 ...
一周排行
    -Advertisement-
    Play Games
  • 前言 本文介紹一款使用 C# 與 WPF 開發的音頻播放器,其界面簡潔大方,操作體驗流暢。該播放器支持多種音頻格式(如 MP4、WMA、OGG、FLAC 等),並具備標記、實時歌詞顯示等功能。 另外,還支持換膚及多語言(中英文)切換。核心音頻處理採用 FFmpeg 組件,獲得了廣泛認可,目前 Git ...
  • OAuth2.0授權驗證-gitee授權碼模式 本文主要介紹如何筆者自己是如何使用gitee提供的OAuth2.0協議完成授權驗證並登錄到自己的系統,完整模式如圖 1、創建應用 打開gitee個人中心->第三方應用->創建應用 創建應用後在我的應用界面,查看已創建應用的Client ID和Clien ...
  • 解決了這個問題:《winForm下,fastReport.net 從.net framework 升級到.net5遇到的錯誤“Operation is not supported on this platform.”》 本文內容轉載自:https://www.fcnsoft.com/Home/Sho ...
  • 國內文章 WPF 從裸 Win 32 的 WM_Pointer 消息獲取觸摸點繪製筆跡 https://www.cnblogs.com/lindexi/p/18390983 本文將告訴大家如何在 WPF 裡面,接收裸 Win 32 的 WM_Pointer 消息,從消息裡面獲取觸摸點信息,使用觸摸點 ...
  • 前言 給大家推薦一個專為新零售快消行業打造了一套高效的進銷存管理系統。 系統不僅具備強大的庫存管理功能,還集成了高性能的輕量級 POS 解決方案,確保頁面載入速度極快,提供良好的用戶體驗。 項目介紹 Dorisoy.POS 是一款基於 .NET 7 和 Angular 4 開發的新零售快消進銷存管理 ...
  • ABP CLI常用的代碼分享 一、確保環境配置正確 安裝.NET CLI: ABP CLI是基於.NET Core或.NET 5/6/7等更高版本構建的,因此首先需要在你的開發環境中安裝.NET CLI。這可以通過訪問Microsoft官網下載並安裝相應版本的.NET SDK來實現。 安裝ABP ...
  • 問題 問題是這樣的:第三方的webapi,需要先調用登陸介面獲取Cookie,訪問其它介面時攜帶Cookie信息。 但使用HttpClient類調用登陸介面,返回的Headers中沒有找到Cookie信息。 分析 首先,使用Postman測試該登陸介面,正常返回Cookie信息,說明是HttpCli ...
  • 國內文章 關於.NET在中國為什麼工資低的分析 https://www.cnblogs.com/thinkingmore/p/18406244 .NET在中國開發者的薪資偏低,主要因市場需求、技術棧選擇和企業文化等因素所致。歷史上,.NET曾因微軟的閉源策略發展受限,儘管後來推出了跨平臺的.NET ...
  • 在WPF開發應用中,動畫不僅可以引起用戶的註意與興趣,而且還使軟體更加便於使用。前面幾篇文章講解了畫筆(Brush),形狀(Shape),幾何圖形(Geometry),變換(Transform)等相關內容,今天繼續講解動畫相關內容和知識點,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 什麼是委托? 委托可以說是把一個方法代入另一個方法執行,相當於指向函數的指針;事件就相當於保存委托的數組; 1.實例化委托的方式: 方式1:通過new創建實例: public delegate void ShowDelegate(); 或者 public delegate string ShowDe ...