C++中的數組你真的理解瞭嗎
1 概述
所謂數組,就是一個集合,裡面存放瞭相同類型的數據元素。
特點1:數組中的每個數據元素都是相同的數據類型。
特點2:數組是由連續的內存位置組成的。
2 一維數組
2.1 一維數組定義方式
一共有三種
1.數據類型 數組名[數組長度]; 2.數據類型 數組名[數組長度]={值1,值2,值3,...}; 3.數據類型 數組名[]={值1,值2,值3,...};
#include<iostream> using namespace std; int main() { //第一種定義數組 int arr[5] ; memset(arr, 0, sizeof(arr));//初始化為0,否則為隨機數 arr[0] = 10; arr[1] = 10; arr[2] = 10; arr[3] = 10; arr[4] = 10; //訪問數組 for (int i = 0; i < 5; i++) { cout << arr[i] << " "; } cout << endl; //第二種定義數組 //如果在初始化的時候沒有填充完,剩餘的會用0來填充。 int brr[5] = { 20,20,20,20 }; for (int i = 0; i < 5; i++) { cout << brr[i] << " "; } cout << endl; //第三種定義數組 char crr[] = { '3','3','3','3','c'}; for (int i = 0; i < 5; i++) { cout << crr[i] << " "; } system("pause"); return 0; }
- 第一種方法是先聲明再定義,對於全局/靜態數組(定義在main()之外的數組),數組內容自動初始化為0。如果是局部的,此時數組的各元素是隨機數,這時可以用
memset(arr, 0, sizeof(arr));
使所有元素初始化為0; - 第二種方法是在定義的時候直接初始化,這時如果在初始化的時候沒有填充完,剩餘的會用0來填充。
- 第三種方法在定義的時候不指定長度,這時會默認數組長度是你所賦的值的數量。
如果引用的索引超出瞭數組長度,也可以輸出,輸出結果是隨機數(int型數組)/ 問號(char型)。
2.2 一維數組組名
一維數組組名用途:
- 可以統計整個數組在內存中的長度。
- 可以獲取數組在內存中的首地址。
註意:數組名是常量,不可以像更改數組元素那樣更改數組名
#include<iostream> using namespace std; int main() { //1.統計內存 int arr[5] = { 1,2,3,4,5 }; cout << "整個數組占用內存空間為:" << sizeof(arr) << endl; cout << "每個元素占用內存空間為:" << sizeof(arr[0]) << endl; //元素內存相同,所以隻看一個就可以瞭。 //2.查看數組首地址 cout << "數組的首地址為(十六進制):" << arr << endl; cout << "數組的首地址為(十進制):" << (int)arr << endl; cout << "數組的第一個元素地址為(十進制):" << (int)&arr[0] << endl; cout << "數組的第二個元素地址為(十進制):" << (int)&arr[1] << endl; //會發現差4個字節,就是一個整型數組的內存大小。 //3.數組名是常量,不可以想更改數組元素那樣更改數組名 //arr=crr system("pause"); return 0; }
練習案例1
#include<iostream> using namespace std; int main() { int arr[5] = { 300,350,200,400,250 }; int size = sizeof(arr) / sizeof(arr[0]); int max = 0; for (int i = 0; i < size; i++) { if (arr[i] > max) { max = arr[i];} } cout << "最重的小豬體重為:" << max << endl; system("pause"); return 0; }
練習案例2
#include<iostream> using namespace std; int main() { int arr[5] = { 1,3,5,9,4 }; int size = sizeof(arr) / sizeof(arr[0]); int start = 0; int end = size - 1; int temp = 0; //打印逆置前的數組 cout << "數組逆置前:" << endl; for (int i = 0; i < size; i++) { cout << arr[i] << " "; } //逆置 while (start < end) { temp = arr[start]; arr[start] = arr[end]; arr[end] = temp; start++; end--; } //打印逆置後的數組 cout << "數組逆置後:" << endl; for (int i = 0; i < size; i++) { cout << arr[i] << " "; } system("pause"); return 0; }
2.3 冒泡排序
作用:最常用的排序算法,對數組內元素進行排序。
方法:
- 比較相鄰的元素。如果第一個比第二 個大, 就交換他們兩個。
- 對每一對相鄰元素做同樣的工作,執行完畢後,找到第一個最大值。
- 重復以上的步驟,每次比較次數-1,直到不需要比較
例如:排序{4,2,8,0,5,7,1,3,9}
#include<iostream> using namespace std; int main() { int arr[] = { 4,8,0,5,7,1,3,0}; int size = sizeof(arr) / sizeof(arr[0]); //打印排序前的數組 cout << "數組排序前:" << endl; for (int i = 0; i < size; i++) { cout << arr[i] << " "; } cout << endl; //冒泡排序 for (int i = 0; i < size-1; i++) //從0開始,共有size-1輪 { for (int j = 0; j + i < size - 1; j++) //每輪的比較次數與當前輪數相加小於size-1 { if (arr[j] > arr[j + 1]) { int temp = arr[j]; arr[j] = arr[j+1]; arr[j + 1] = temp; } } } cout << "數組排序後:" << endl; for (int i = 0; i < size; i++) { cout << arr[i] << " "; } cout << endl; system("pause"); return 0; }
3 二維數組
二維數組就是在一維數組上,多加一個維度。
3.1 二維數組定義方式
1.數據類型 數組名[行數][列數]; 2.數據類型 數組名[行數][列數]={{數據1,數據2},{數據3,數據4}}; 3.數據類型 數組名[行數][列數]={數據1,數據2,數據3,數據4}; 4.數據類型 數組名[][列數]={數據1,數據2,數據3,數據4};
一般都是使用第二種,因為第二種最直觀,提高代碼的可讀性。
#include<iostream> using namespace std; int main() { //1.數據類型 數組名[行數][列數]; //2.數據類型 數組名[行數][列數] = { {數據1,數據2},{數據3,數據4} }; //3.數據類型 數組名[行數][列數] = { 數據1,數據2,數據3,數據4 }; //4.數據類型 數組名[][列數] = { 數據1,數據2,數據3,數據4 }; //1. int arr[2][3]; arr[0][0] = 0; arr[0][1] = 1; arr[0][2] = 2; arr[1][0] = 3; arr[1][1] = 4; arr[1][2] = 5; for (int i = 0; i < 2; i++) { for (int j = 0; j < 3; j++) { cout << arr[i][j] << "\t"; } cout << endl; } cout << endl; //2. int brr[2][3] = { {1,2,3}, {4,5,6} }; for (int i = 0; i < 2; i++) { for (int j = 0; j < 3; j++) { cout << brr[i][j] << "\t"; } cout << endl; } cout << endl; //3. int crr[2][3] = { 1,2,3,4,5,6 }; for (int i = 0; i < 2; i++) { for (int j = 0; j < 3; j++) { cout << crr[i][j] << "\t"; } cout << endl; } cout << endl; //4. int drr[][3] = { 1,2,3,4,5,6 }; for (int i = 0; i < 2; i++) { for (int j = 0; j < 3; j++) { cout << drr[i][j] << "\t"; } cout << endl; } system("pause"); return 0; }
3.2 二維數組數組名
查看二維數組所占內存空間或者某行占用內存空間
#include<iostream> using namespace std; int main() { int arr[2][3] = { {1,2,3}, {4,5,6} }; cout << "二維數組占用內存為:" << sizeof(arr) << endl; cout << "某一行占用內存為:" << sizeof(arr[0]) << endl; cout << "一個元素占用內存為:" << sizeof(arr[0][0]) << endl; int row = sizeof(arr) / sizeof(arr[0]); int column = sizeof(arr[0]) / sizeof(arr[0][0]); cout << "數組的行數為:" << row << "\n" << "數組的列數為:" << column << endl; cout << "二維數組的首地址是(16進制):" << arr << endl; cout << "二維數組的首地址是(10進制):" << (int)arr << endl; cout << "第一行首地址是(10進制):" << (int)arr[0] << endl; cout << "第二行首地址是(10進制):" << (int)arr[1] << endl; //會發現第一行和第二行差12,正好三個整型元素 cout << "第二行第一個元素地址是(10進制):" << (int)&arr[1][0] << endl;//直接使用arr[1][0]是查看這個元素內容,需要用&取地址。 system("pause"); return 0; }
3.3二維數組應用舉例
#include<iostream> using namespace std; //vs快捷鍵crtl+d可以直接把本行復制到下行 int main() { int arr[3][3] = { {100,100,100}, {90 ,50 ,100}, {60, 70 ,80 } }; cout << "成績情況為:" << endl; for (int i = 0; i < 3; i++) { for (int j = 0; j < 3; j++) { cout << arr[i][j] << " "; } cout << endl; } string names[3] = { "張三","李四","王五" }; for (int i = 0; i < 3; i++) { int sum = 0; for (int j = 0; j < 3; j++) { sum += arr[i][j]; } cout << names[i] << "的總成績為:" << sum << endl; } system("pause"); return 0; }
總結
本篇文章就到這裡瞭,希望能夠給你帶來幫助,也希望您能夠多多關註WalkonNet的更多內容!
推薦閱讀:
- 聊聊c++數組名稱和sizeof的問題
- C++的數據類型你真的瞭解嗎
- 手把手帶你學習C++的數據類型
- 一篇文章徹底搞懂C++常見容器
- C++中獲取字符串長度的函數sizeof()、strlen()、length()、size()詳解和區別(推薦)