<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
所謂陣列,就是一個集合,裡面存放了相同型別的資料元素。
特點1:陣列中的每個資料元素都是相同的資料型別。
特點2:陣列是由連續的記憶體位置組成的。
一共有三種
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; }
memset(arr, 0, sizeof(arr));
使所有元素初始化為0;如果參照的索引超出了陣列長度,也可以輸出,輸出結果是亂數(int型陣列)/ 問號(char型)。
一維陣列組名用途:
注意:陣列名是常數,不可以像更改陣列元素那樣更改陣列名
#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; }
作用:最常用的排序演演算法,對陣列內元素進行排序。
方法:
例如:排序{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; }
二維陣列就是在一維陣列上,多加一個維度。
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; }
檢視二維陣列所佔記憶體空間或者某行佔用記憶體空間
#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; }
#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; }
本篇文章就到這裡了,希望能夠給你帶來幫助,也希望您能夠多多關注it145.com的更多內容!
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45