成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

詳解C++數據結構向量和數組

開發 后端
#include,是一個預處理器指令,它告訴編譯器包含后面的任何庫。在我們的例子中,這是標準vector庫。數組用于在單個變量中存儲多個值,而不是為每個值聲明單獨的變量。

[[404348]]

向量

#include,是一個預處理器指令,它告訴編譯器包含后面的任何庫。在我們的例子中,這是標準vector庫。

  1. #include <vector> 

創建向量的語法如下所示:

  1. std::vector<type> name

比如要定義一個int的向量calories_today:

  1. std::vector<int> calories_today; 

尖括號內是向量的數據類型。尖括號之后是向量的名稱。

注意:vector 的類型(即里面存放的是什么數據類型)在聲明后是不能改變的。

初始化向量

  1. std::vector<double> some_vector = {0.25, 0.50, 0.75, 1.00}; 

現在我們有了一個向量,我們如何訪問單個元素?這就是索引發揮作用的地方。

向量是 0 索引的,這意味著第一個元素的索引為 0,第二個索引為 1,依此類推vector[index]在向量名稱和內部元素的索引號之后,使用帶方括號的表示法。

  1. #include <iostream> 
  2. #include <vector> 
  3.  
  4. int main() 
  5.     std::vector<double> some_vector = {0.25, 0.50, 0.75, 1.00}; 
  6.     std::cout << some_vector[0] << "\n"
  7.     std::cout << some_vector[1] << "\n"
  8.     std::cout << some_vector[2] << "\n"
  9.     std::cout << some_vector[3] << "\n"
  10.  
  11. 0.25 
  12. 0.5 
  13. 0.75 

添加和刪除元素

要將新元素添加到向量的末尾,我們可以使用該.push_back()函數。

  1. #include <iostream> 
  2. #include <vector> 
  3.  
  4. int main() 
  5.     std::vector<double> some_vector = {0.25, 0.50, 0.75, 1.00}; 
  6.     some_vector.push_back(2); 
  7.     std::cout << some_vector[4] << "\n"

還可以使用.pop_back().從向量的“后面”刪除元素。

  1. some_vector.pop_back(); 

向量的大小

不僅存儲元素;它還存儲向量的大小:

.size()函數返回向量中的元素數

  1. #include <iostream> 
  2. #include <vector> 
  3.  
  4. int main() 
  5.     std::vector<double> some_vector = {5,7,9,4,6,8}; 
  6.     std::cout << some_vector.size() << "\n"

向量操作

我們可以使用for循環,可以更改向量中的每個值

  1. #include <iostream> 
  2. #include <vector> 
  3.  
  4. int main() 
  5.     std::vector<double> vector = {5, 7, 9, 4, 6, 8}; 
  6.     for (int i = 0; i < vector.size(); i++) 
  7.     { 
  8.         vector[i] = vector[i] + 10; 
  9.         std::cout << vector[i]  << "\n"
  10.     } 
  11.  
  12. 15 
  13. 17 
  14. 19 
  15. 14 
  16. 16 
  17. 18 

編寫一個程序來計算向量中偶數之和與奇數之積。

假設我們有一個向量是{2, 4, 3, 6, 1, 9}。

然后程序應該輸出

  1. Sum of even numbers is 12 
  2. Product of odd numbers is 27 

具體代碼如下

  1. #include <iostream> 
  2. #include <vector> 
  3.  
  4. int main() 
  5.     int total_even = 0; 
  6.     int product_odd = 1; 
  7.  
  8.     std::vector<int> vector = {2, 4, 3, 6, 1, 9}; 
  9.     for (int i = 0; i < vector.size(); i++) 
  10.     { 
  11.         if (vector[i] % 2 == 0){ 
  12.            total_even = vector[i] + total_even; 
  13.         }else
  14.            product_odd = vector[i] * product_odd; 
  15.         } 
  16.     } 
  17.     std::cout << "Sum of even: " << total_even << "\n"
  18.     std::cout << "Product of odd: " << product_odd; 

數組

數組用于在單個變量中存儲多個值,而不是為每個值聲明單獨的變量。

要聲明數組,請定義變量類型,指定數組的名稱,后跟方括號 并指定它應存儲的元素數:

  1. int score[4]; 

我們現在已經聲明了一個包含四個int數組的變量。要向其中插入值,在大括號內,我們可以使用將值放在逗號分隔的列表中,

  1. int score[4] = {1,2,3,4} 

下面是數組具體的定義和取值的方式

  1. #include <iostream> 
  2. using  namespace std; 
  3. int main() { 
  4.  
  5.  //定義方式1 
  6.  //數據類型 數組名[元素個數]; 
  7.  int score[10]; 
  8.  
  9.  //利用下標賦值 
  10.  score[0] = 100; 
  11.  score[1] = 99; 
  12.  score[2] = 85; 
  13.  
  14.  //利用下標輸出 
  15.  cout << score[0] << endl; 
  16.  cout << score[1] << endl; 
  17.  cout << score[2] << endl; 
  18.  
  19.  
  20.  //第二種定義方式 
  21.  //數據類型 數組名[元素個數] =  {值1,值2 ,值3 ...}; 
  22.  //如果{}內不足10個數據,剩余數據用0補全 
  23.  int score2[10] = { 100, 90,80,70,60,50,40,30,20,10 }; 
  24.   
  25.  //逐個輸出 
  26.  //cout << score2[0] << endl; 
  27.  //cout << score2[1] << endl; 
  28.  
  29.  //一個一個輸出太麻煩,因此可以利用循環進行輸出 
  30.  for (int i = 0; i < 10; i++) 
  31.  { 
  32.   cout << score2[i] << endl; 
  33.  } 
  34.  
  35.  //定義方式3 
  36.  //數據類型 數組名[] =  {值1,值2 ,值3 ...}; 
  37.  int score3[] = { 100,90,80,70,60,50,40,30,20,10 }; 
  38.  for (int i = 0; i < 10; i++) 
  39.  { 
  40.   cout << score3[i] << endl; 
  41.  } 
  42.  

假設我們有一個數組是{ 4,2,8,0,5,7,1,3,9 }。編寫一個程序來實現冒泡排序。

具體代碼如下

  1. #include <iostream> 
  2. using namespace std; 
  3. int main() { 
  4.  
  5.  int arr[9] = { 4,2,8,0,5,7,1,3,9 }; 
  6.  
  7.  for (int i = 0; i < 9 - 1; i++) 
  8.  { 
  9.   for (int j = 0; j < 9 - 1 - i; j++) 
  10.   { 
  11.    if (arr[j] > arr[j + 1]) 
  12.    { 
  13.     int temp = arr[j]; 
  14.     arr[j] = arr[j + 1]; 
  15.     arr[j + 1] = temp
  16.    } 
  17.   } 
  18.  } 
  19.  
  20.  for (int i = 0; i < 9; i++) 
  21.  { 
  22.   cout << arr[i] << endl; 
  23.  } 
  24.      
  25.  

 【編輯推薦】

 

責任編輯:姜華 來源: Python之王
相關推薦

2024-01-15 06:01:36

C++數組

2012-02-02 10:21:05

單鏈表nexthead

2010-01-27 15:58:35

C++數據結構

2011-04-11 17:09:37

稀疏矩陣矩陣C++

2023-09-15 10:33:41

算法數據結構

2011-04-11 11:23:17

隊列數據結構

2011-04-11 12:22:11

數據結構C++

2011-04-11 12:48:36

隊列數據結構C++

2009-11-09 11:05:41

ibmdwRational

2023-03-28 07:44:23

數據結構數組

2011-07-20 17:10:54

C++

2023-12-13 10:01:15

數據結構c++編程

2020-06-29 07:44:36

Redis

2024-03-14 11:54:37

C++數據類型

2019-10-29 08:59:16

Redis底層數據

2013-05-10 15:27:07

R語言

2009-08-03 17:38:12

排序算法C#數據結構

2016-08-24 20:09:27

Linux數據結構位數組

2019-06-10 14:45:26

面試數據結構算法

2021-05-21 08:31:09

數據結構二叉樹
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 一区二区久久电影 | 精品国产乱码久久久 | www.蜜桃av| 亚洲精品粉嫩美女一区 | 一区二区中文 | 亚洲色图插插插 | 欧美日韩电影免费观看 | 男人久久天堂 | 亚洲三区在线 | 国产成人短视频在线观看 | 美日韩免费视频 | 成人精品久久日伦片大全免费 | 欧美精品综合 | 欧美h版| 亚洲综合一区二区三区 | 久久毛片 | 日韩在线免费 | 第四色影音先锋 | 欧美亚洲国产日韩 | www.日韩 | 欧美一a一片一级一片 | 亚洲一区二区三区四区五区中文 | 麻豆久久久久久久 | 亚洲欧美一区二区三区1000 | 免费看欧美一级片 | 国产精品成人一区二区三区 | 精品亚洲一区二区 | 日本久久精品视频 | 欧美a区| 天天精品综合 | 国产色| 色综合一区二区 | 久久久久久久久久久爱 | 日韩精品久久久 | 国产精品视频播放 | 青青激情网 | 精品不卡 | 色伊人 | 日本不卡免费新一二三区 | 国产高清精品一区二区三区 | 一级在线观看 |