欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C++利用數(shù)組(一維/二維)處理批量數(shù)據(jù)的方法

 更新時間:2023年10月08日 09:37:41   作者:衛(wèi)衛(wèi)周大胖;  
對于簡單的問題,使用簡單的數(shù)據(jù)類型就可以了,但是對于有些需要處理的數(shù)據(jù),只用以上簡單的數(shù)據(jù)類型是不夠的,難以反映出數(shù)據(jù)的特點(diǎn),也難以有效的進(jìn)行處理,本文小編給大家介紹了C++利用數(shù)組(一維/二維)處理批量數(shù)據(jù)的方法,需要的朋友可以參考下

怎樣定義和引用一維數(shù)據(jù)

  • 一維數(shù)組是數(shù)組中最簡單的,它的元素只需要用數(shù)組名加一個下標(biāo),就能唯一的地確定。
  • 數(shù)組是一組有序數(shù)據(jù)的集合
  • 數(shù)組中的每一個元素都屬于同一個數(shù)據(jù)類型
  • C語言規(guī)定用方括號中的數(shù)字表示下標(biāo),如S[15]表示第15個元素

怎樣定義一維數(shù)組

要使用數(shù)組,必須在程序中先定義數(shù)組,即通知計算機(jī):由哪些數(shù)據(jù)組成數(shù)組,數(shù)組中有多少元素,屬于哪個數(shù)據(jù)類型。否則計算機(jī)不會自動的把一批數(shù)據(jù)作為數(shù)組處理。例如,下面是對數(shù)組的定義:

int a[10] ;

它表示定義了一個整型數(shù)組, 數(shù)組名是a,此數(shù)組包含了 10個元素。

數(shù)組的一般形式為:

類型說明符 數(shù)組名[常量表達(dá)式]

說明:

  • 數(shù)組名的命名規(guī)則和變量名相同,遵循標(biāo)識符命名規(guī)則。
  • 在定義數(shù)組時莫須有指定數(shù)組中元素的個數(shù),方括號中的常量表達(dá)式用來表示元素的個數(shù),即數(shù)組的長度。
  • 常量表達(dá)式中可以包括常量和符號常量,如 int a[3 + 5]是合法的的。
  • 用 “int a[10];”定義了數(shù)組后a后,在內(nèi)存中劃出了一片存儲空間(下圖所示),存放了一個有10個整型元素的數(shù)組,可以看到,用一個 “int a[10];”就相當(dāng)于定義了10個簡單的整型變量,顯然簡單方便。

在這里插入圖片描述

怎樣引用一維數(shù)組

在定義數(shù)組并對其各個元素賦值后,就可以引用數(shù)組中的元素。應(yīng)注意:只能引用數(shù)組元素而不能一次整體調(diào)用整個數(shù)組全部元素的值。

引用數(shù)組元素的表示形式為:

數(shù)組名[下標(biāo)]

例題: 對10個數(shù)組元素一次賦值為0,1,2,3 … 8,9,要求逆序輸出。

int main()
{
	int i = 0;
	int arr[10] = { 0 };
	for (i = 0; i < 10; i++)
	{
		arr[i] = i;//賦值
	}
	for (i = 9; i >= 0; i--)
	{
		printf("%d ", arr[i]);//打印
	}
	printf("\n");
	return 0;
}

運(yùn)行結(jié)果:

在這里插入圖片描述

一維數(shù)組的初始化

在定義數(shù)組時對全部數(shù)組元素賦予初值。例如:

int a[10] = {0,1,2,3,4,5,6,7,8,9);

也可只給數(shù)組中的一部分元素賦值。例如:

int a[10] = {0,1,2,3,4};
//定義a數(shù)組有10個元素,但花括號內(nèi)只提供5個元素的初始值,
//系統(tǒng)自動給后面5個元素的初始值賦值為0

如果想一個數(shù)組中全部元素為0,可以寫成:

int a[10] = {0};

在對全部數(shù)組元素賦初始值時,由于數(shù)據(jù)的個數(shù)已經(jīng)確定,因此可以不指定數(shù)組長度。例如:

int a[5] = {1,2,3,4,5};
//或者
int a[] = {1,2,3,4,5}; 

一維數(shù)組程序舉例

例題1:用數(shù)組來處理求Fibonacci(斐波那契數(shù)列)問題。這個數(shù)列有以下特點(diǎn):第1,2兩個數(shù)為1,1。從第3個數(shù)開始,該數(shù)是其前面兩個數(shù)之和。即該數(shù)列為1,1,2,3,5,8,13…,求其前20個數(shù)。

int main()
{
	int i = 0;
	int arr[20] = {1,1};//前倆項(xiàng)賦值為1
	for (i = 2; i < 20; i++)
	{
		arr[i] = arr[i - 1] + arr[i - 2];
	}
	for (i = 0; i < 20; i++)
	{
		printf("%d ", arr[i]);
	}
	printf("\n");
	return 0;
}

運(yùn)行結(jié)果:

在這里插入圖片描述

例題2(冒泡排序):有10個地區(qū)的面積,要求對它們按由小到大的順序排序。

int main()
{
	int area[10] = { 0 };
	int i = 0;
	int j = 0;
	int min = 0;
	printf("請分別輸入10個田地的面積\n");
	for (i = 0; i < 10; i++)
	{
		scanf("%d", &area[i]);
	}
	for (i = 0; i < 9; i++)//排升序(趟數(shù))
	{
		for (j = 0; j < 9 - i; j++)//兩兩交換
		{
			if (area[j] > area[j + 1])
			{
				min = area[j + 1];//將較小的放臨時變量中
				area[j + 1] = area[j];//將兩交換位置
				area[j] = min;//將較小值賦值給較大值
			}
		}
	}
	for (i = 0; i < 10; i++)
	{
		printf("%d ", area[i]);
	}
	printf("\n");
	return 0;
}

運(yùn)行結(jié)果:

在這里插入圖片描述

怎樣定義和引用二維數(shù)組

前面已經(jīng)提到,有的問題需要用二維數(shù)組來處理。例如3個小分隊(duì),每隊(duì)有6名隊(duì)友,需要把這些隊(duì)友的工資用數(shù)組保存起來以備查。這就需要用到二維數(shù)組(如下圖)。如果建立一個數(shù)組Pay,它應(yīng)當(dāng)是二維的,第一維用來表示第幾個分隊(duì),第二維用來表示第幾個隊(duì)員。

在這里插入圖片描述

二維數(shù)組通常稱為 矩陣 。把二維數(shù)組寫成行(row)和列(column)的排列形式,可以有助于形象化的理解二維數(shù)組的邏輯結(jié)構(gòu)。

怎樣定義二維數(shù)組

怎樣定義二維數(shù)組呢? 其基本概念與方法和一維數(shù)組相似。如:

float pay[3][6]

以上定義了一個float類型的二維數(shù)組,第1維有3個元素,第2維有6個元素。每一維的長度分別用一對方括號擴(kuò)起來。 二維數(shù)組的一般定義形式如下: 類型說明符 數(shù)組名[常量表達(dá)式][常量表達(dá)式]

例如: float a[3][4],b[5][10];

C語言對二維數(shù)組采用這樣的定義方式,使得二維數(shù)組可以被看作一種特殊的一維數(shù)組:它的元素又是一個一維數(shù)組。例如可以把a看作一個一維數(shù)組,它有3個元素:a[0],a[1],a[2],每個元素又是一個包含4元素的一維數(shù)組,如圖所示

在這里插入圖片描述

我們可以把a(bǔ)[0],a[1], a[2]看成三個一維數(shù)組的名字。上面定義的二維數(shù)組可以理解為定義了3個一維數(shù)組,即相當(dāng)于:

float a[0][4],a[1][4],a[2][4]

此處把a(bǔ)[0],a[1],a[2]看作一維數(shù)組名。C語言的這種處理方法在數(shù)組初始化和用指針表示時顯得很方便,這在以后的使用中各位會經(jīng)常體會到。

二維數(shù)組在內(nèi)存中存放的順序

C語言中,二維數(shù)組中元素排放的順序是按行存放的,即在內(nèi)存中先順序存放第一行的元素,接著存放第2行的元素。如下圖所示:

在這里插入圖片描述

怎樣引用二維數(shù)組

二維數(shù)組元素的表示形式為:

數(shù)組名[下標(biāo)][下標(biāo)]

例如:a[2][3]表示a數(shù)組中序號為2的行中序號為3的列元素。下標(biāo)應(yīng)是整型表達(dá)式,如 a[2 - 1][2 * 2 - 1]形式。 數(shù)組元素可以出現(xiàn)在表示中也可以被賦值。

二維數(shù)組的初始化

分行給二維數(shù)組賦初始值。 這種賦初始值的方式比較直觀,把第一個花括號內(nèi)的數(shù)據(jù)給第1行的元素,第2個花括號內(nèi)的值給第2行的元素。例如:

int a[3][4] = {{1,2,3,4},{5,6,7,8},{9,10,11,12}};

可以將所有數(shù)據(jù)寫在一個花括號內(nèi),按數(shù)組元素在內(nèi)存中的排列順序?qū)Ω髟刭x初始值。例如:

int a[3][4] = {1,2,3,4,5,6,7,8,9,10,11,12,};

可以對部分元素賦初始值,例如:

int a[3][4] = {{1},{5},{9}};

二維數(shù)組程序舉例

例題:有一個3 * 4的矩陣,要求編寫程序求出求字最大的那個元素的值,以及其所在的行號和列號。

int main()
{
	int arr[3][4] = { {1,2,3,4},{5,55,7,8},{9,55,11,12} };
	int i = 0;
	int j = 0;
	int max = 0;//最大值
	int col = 0;//列坐標(biāo)
	int row = 0;//行坐標(biāo)
	for (i = 0; i < 3; i++)
	{
		for (j = 0; j < 4; j++)
		{
			if (max  < arr[i][j])//將數(shù)組中的每一個元素和它進(jìn)行比較找出最大的
			{
				max = arr[i][j];
				row = i;
				col = j;
			}
		}
	}
	printf("row = %d col = %d max = %d \n", row,col,max);
	return 0;
}

運(yùn)行結(jié)果:

在這里插入圖片描述

以上就是C++利用數(shù)組(一維/二維)處理批量數(shù)據(jù)的方法的詳細(xì)內(nèi)容,更多關(guān)于C++利用數(shù)組處理數(shù)據(jù)的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • C++中auto類型說明符詳解(附易錯實(shí)例)

    C++中auto類型說明符詳解(附易錯實(shí)例)

    這篇文章主要給大家介紹了關(guān)于C++中auto類型說明符的相關(guān)資料,文中還附易錯實(shí)例,在C++11中引入了auto類型說明符,用它就能讓編譯器替我們?nèi)シ治霰磉_(dá)式所屬的類型,需要的朋友可以參考下
    2023-07-07
  • C++ COM編程之QueryInterface函數(shù)(一)

    C++ COM編程之QueryInterface函數(shù)(一)

    這篇文章主要介紹了C++ COM編程之QueryInterface函數(shù)(一),QueryInterface是組件本身提供對自己查詢的一個接口,需要的朋友可以參考下
    2014-10-10
  • C語言實(shí)現(xiàn)掃雷小游戲簡單版

    C語言實(shí)現(xiàn)掃雷小游戲簡單版

    這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)掃雷小游戲簡單版,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • C語言實(shí)現(xiàn)順序表的全操作詳解

    C語言實(shí)現(xiàn)順序表的全操作詳解

    順序表,全名順序存儲結(jié)構(gòu),是線性表的一種,線性表用于存儲邏輯關(guān)系為“一對一”的數(shù)據(jù),順序表自然也不例外,不僅如此,順序表對數(shù)據(jù)的物理存儲結(jié)構(gòu)也有要求,跟隨下文來具體了解吧
    2022-04-04
  • C++實(shí)現(xiàn)LeetCode(191.位1的個數(shù))

    C++實(shí)現(xiàn)LeetCode(191.位1的個數(shù))

    這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(191.位1的個數(shù)),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-08-08
  • 詳解C++ 參數(shù)的三種傳遞方式和應(yīng)用場景

    詳解C++ 參數(shù)的三種傳遞方式和應(yīng)用場景

    這篇文章主要介紹C++ 參數(shù)的三種傳遞方式和應(yīng)用場景,C++ 參數(shù)的三種傳遞方式分別是值傳遞、指針傳遞和引用傳遞,感興趣的同學(xué)可以參考閱讀下
    2023-06-06
  • C++計算任意權(quán)值的單源最短路徑(Bellman-Ford)

    C++計算任意權(quán)值的單源最短路徑(Bellman-Ford)

    這篇文章主要為大家詳細(xì)介紹了C++計算任意權(quán)值的單源最短路徑,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-04-04
  • opencv配置的完整步驟(win10+VS2015+OpenCV3.1.0)

    opencv配置的完整步驟(win10+VS2015+OpenCV3.1.0)

    OpenCV是計算機(jī)視覺中經(jīng)典的專用庫,其支持多語言、跨平臺,功能強(qiáng)大,這篇文章主要給大家介紹了關(guān)于opencv配置(win10+VS2015+OpenCV3.1.0)的相關(guān)資料,需要的朋友可以參考下
    2021-06-06
  • C++中小數(shù)點(diǎn)輸出格式(實(shí)例代碼)

    C++中小數(shù)點(diǎn)輸出格式(實(shí)例代碼)

    下面小編就為大家?guī)硪黄狢++中小數(shù)點(diǎn)輸出格式(實(shí)例代碼)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • C語言中強(qiáng)制類型轉(zhuǎn)換的常見方法

    C語言中強(qiáng)制類型轉(zhuǎn)換的常見方法

    強(qiáng)制類型轉(zhuǎn)換是一種將一個數(shù)據(jù)類型轉(zhuǎn)換為另一個數(shù)據(jù)類型的方法,這篇文章主要為大家整理了C語言中強(qiáng)制類型轉(zhuǎn)換的方法,需要的可以參考一下
    2023-05-05

最新評論