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

一篇文章帶你入門C語言數(shù)據(jù)結構:緒論

 更新時間:2021年08月03日 15:18:46   作者:AKA你的閨蜜  
這篇文章主要介紹了C語言的數(shù)據(jù)解構基礎,希望對廣大的程序愛好者有所幫助,同時祝大家有一個好成績,需要的朋友可以參考下,希望能給你帶來幫助

緒論

什么是數(shù)據(jù)結構?

不同于計算機操作培訓,注意與程序設計的區(qū)別。

Example 1

求n個數(shù)的最大值、次最大值。

//1.遍歷 - 最樸素的方法
int main()
{
	int arr[10] = { 22,334,552,1,4,6,78,23,55,98 };
	int i = 0;
	int temp = 0;
	int max1 = arr[0];
	int max2 = arr[1];
	for (i = 1; i < 10; i++)
	{
		if (arr[i] > max1)
		{
			temp = max1;
			max1 = arr[i];
			arr[i] = temp;
		}
	}
	printf("%d\n", max1);
	for (i = 2; i < 10; i++)
	{
		if (arr[i] > max2)
		{
			temp = max2;
			max2 = arr[i];			arr[i] = temp;
		}
	}
	printf("%d\n", max2); 
	return 0;
}
遍歷方法共需進行 n − 1 + n − 2 = 2 n − 3 n-1+n-2=2n-3 n−1+n−2=2n−3次比較。

變題

有n個足球隊比賽,問至少多少次比賽才能找到冠軍和亞軍。

解:
實際中通常采用錦標賽方法。(淘汰制)
設有8個數(shù)分別為5,7,3,6,8,9,4,2
兩兩為一組進行比較,大的勝出,小的淘汰。

錦標賽1

毋庸置疑的是,無論怎么分組,顯然最大值永遠不會被淘汰。故最大值為9。

共進行了 8 / 2 + 4 / 2 + 2 / 2 = 7 8/2+4/2+2/2=7 8/2+4/2+2/2=7次比較。

故變題尋找冠軍的比較次數(shù)為 n / 2 + n / 2 2 + … + n / 2 k = n − 1 n/2+n/2^2+…+n/2^k=n-1 n/2+n/22+…+n/2k=n−1

錦標賽2

次最大值肯定是被最大值給比下去了,不然它就是最大值了。所以順著這個思路,把所有和最大值進行過直接比較的數(shù)字跳出來,重新進行比較。

就是如圖所示帶*的數(shù)字,個數(shù)記為k,稍加思索則得出 k = l o g 2 n k=log_2{n} k=log2​n

2.故變題尋找亞軍的比較次數(shù)為 l o g 2 n − 1 log_2{n}-1 log2​n−1

錦標賽方法共需 n − 1 + l o g 2 n − 1 = n + l o g 2 n − 2 n-1+log_2{n}-1=n+log_2{n}-2 n−1+log2​n−1=n+log2​n−2次比較。

課后思考:將該模型用C程序編寫出來。

討論

​ 處理一般實際工程問題的方法。

  • 找出解決方案。
  • 找出最優(yōu)解。(最節(jié)省資源:CPU和內存)

計算機模型

Example 2

判斷表達式中括號是否匹配

Z = ( ( a + b ) + c ) ∗ 2 + ( 3 − 5 ) / 7 − ( ( 6 + 2 ) / 8 + a )

void match(char* ch)
{
	int count = 0;
	int i = 0; 
	while (ch[i]!= ';') 
	{
		if(ch[i] == '(')
			count++;
		else if (ch[i] ==')')
			count--; 
		i++;
	}
	if (count != 0)
		printf("%s\n","no match");
	else 
		printf("%s\n","match");
}

當然,上述代碼是由左向右數(shù)括號數(shù)是否相等來判斷括號是否匹配,很容易就可以舉出反例 f = ) a + b ( f=)a+b( f=)a+b( ,所有該方法是不成熟的。

Example 3

交叉路口交通管理系統(tǒng)

岔路口

  • 把可以走通的道路設為頂點
  • 如果兩個頂點有沖突,用頂點之間的連線表示

變題 著色算法

在狀態(tài)圖中,相鄰(有連線)的頂點不能是同一種狀態(tài)。故對于頂點的不同狀態(tài),我們用不同的顏色去表示。由于四色定理,多余5叉的路口不能用少于4種顏色來表示。

在狀態(tài)圖中至少需要多少種顏色來表示?

Example 4

如何快速走出迷宮?

走迷宮

以上問題現(xiàn)階段并不作要求,目的是向大家介紹下數(shù)據(jù)結構的研究問題。

現(xiàn)在我們是否能回答出剛開始時問大家的問題呢?數(shù)據(jù)結構是什么?

數(shù)據(jù)結構是研究的是非數(shù)值計算的程序設計方法。

在這里插入圖片描述

總結

本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關注腳本之家的更多內容!

相關文章

  • C++ 實現(xiàn)靜態(tài)單鏈表的實例

    C++ 實現(xiàn)靜態(tài)單鏈表的實例

    這篇文章主要介紹了C++ 實現(xiàn)靜態(tài)單鏈表的實例的相關資料,需要的朋友可以參考下
    2017-06-06
  • C++基于Directx MMX實現(xiàn)的圖像灰度轉換代碼

    C++基于Directx MMX實現(xiàn)的圖像灰度轉換代碼

    這篇文章主要介紹了C++基于Directx MMX實現(xiàn)的圖像灰度轉換代碼,需要的朋友可以參考下
    2014-08-08
  • 使用c語言輕松實現(xiàn)動態(tài)內存管

    使用c語言輕松實現(xiàn)動態(tài)內存管

    這篇文章主要介紹了使用c語言輕松實現(xiàn)動態(tài)內存管,本文章內容詳細,具有很好的參考價值,希望對大家有所幫助,需要的朋友可以參考下
    2023-01-01
  • C++超詳細探究new/delete的使用

    C++超詳細探究new/delete的使用

    這篇文章主要介紹了C++中new與deleted關鍵字的使用,new在動態(tài)內存中為對象分配空間并返回一個指向該對象的指針;delete接受一個動態(tài)對象的指針, 銷毀該對象, 并釋放與之關聯(lián)的內存
    2022-07-07
  • C語言基礎解析之分支與循環(huán)語句

    C語言基礎解析之分支與循環(huán)語句

    C語言是一門結構化的程序設計語言,當C語言用來描述生活中的事物時,會用到三種結構:順序結構(不去贅述),選擇結構(對應分支語句),循環(huán)結構(對應循環(huán)語句),分支語句:分支語句分為兩種,一種是if語句,一種是switch語句
    2021-09-09
  • 使用C語言訪問51單片機中存儲器的核心代碼

    使用C語言訪問51單片機中存儲器的核心代碼

    這篇文章主要介紹了使用C語言訪問51單片機中存儲器的相關知識,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-01-01
  • C++使用回溯法解決黃金礦工問題

    C++使用回溯法解決黃金礦工問題

    在矩陣中考察回溯算法,分為任意起點、左上角開始等情況。從而有不同的模板,其實區(qū)別就是直接開始還是每個坐標都去嘗試,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-10-10
  • c++類構造函數(shù)詳解

    c++類構造函數(shù)詳解

    這篇文章主要介紹了c++類構造函數(shù)示例,需要的朋友可以參考下
    2014-05-05
  • 用C語言實現(xiàn)簡易通訊錄

    用C語言實現(xiàn)簡易通訊錄

    這篇文章主要為大家詳細介紹了用C語言實現(xiàn)簡易通訊錄,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-02-02
  • C語言直接選擇排序算法詳解

    C語言直接選擇排序算法詳解

    直接選擇排序就是遍歷整個數(shù)組,每遍歷一遍的目的是找出該數(shù)組中的最大數(shù)和最小數(shù)對應的下標,然后將最小數(shù)和數(shù)組的第一個數(shù)進行交換,最大數(shù)和數(shù)組的最后一個數(shù)進行交換,然后縮小范圍再次遍歷
    2022-08-08

最新評論