c語(yǔ)言實(shí)現(xiàn)隊(duì)列算法 從一個(gè)棧創(chuàng)建一個(gè)隊(duì)列,使棧頂為隊(duì)列的頭,棧底為隊(duì)列的尾,最后要求使棧成為空棧 (用C語(yǔ)言實(shí)現(xiàn))?
從一個(gè)棧創(chuàng)建一個(gè)隊(duì)列,使棧頂為隊(duì)列的頭,棧底為隊(duì)列的尾,最后要求使棧成為空棧 (用C語(yǔ)言實(shí)現(xiàn))?這里我用C語(yǔ)言實(shí)現(xiàn)了堆棧,代碼附在文本上。1. 堆棧表示堆棧遵循先入后出的原則,所以我們需要頂部和底部指
從一個(gè)棧創(chuàng)建一個(gè)隊(duì)列,使棧頂為隊(duì)列的頭,棧底為隊(duì)列的尾,最后要求使棧成為空棧 (用C語(yǔ)言實(shí)現(xiàn))?
這里我用C語(yǔ)言實(shí)現(xiàn)了堆棧,代碼附在文本上。
1. 堆棧表示
堆棧遵循先入后出的原則,所以我們需要頂部和底部指針。讓我們用len表示當(dāng)前堆棧中有多少元素,用stack size表示堆??梢源鎯?chǔ)多少元素。以整數(shù)為例。
2. 要?jiǎng)?chuàng)建堆棧,使用malloc函數(shù)分配空間,使基指針指向空間的起始位置,并將頂部指針設(shè)置為底部指針。設(shè)len為0,stacksize為初始堆棧的最大值。這樣,堆棧就被初始化了。注意:Max_u2;在進(jìn)入堆棧時(shí),我們首先考慮堆棧是否已滿。如果已經(jīng)滿了,我們需要增加分配的空間。Realloc函數(shù)可以用來動(dòng)態(tài)分配空間。具體用途可在線查詢。然后將stack元素指定給top指針指向的空間,并設(shè)置top 1。這樣,就完成了一個(gè)堆棧條目。
4. 離開堆棧前檢查堆棧是否為空。如果為空,則會(huì)報(bào)告錯(cuò)誤。如果不為空,則堆棧頂部指針將減少1(此處的堆棧頂部指針指向要放入堆棧的空間,因此離開堆棧時(shí)將減少1)。然后將指向空間的上指針的值賦給容器,并將長(zhǎng)度減少1。
5. 銷毀堆棧。銷毀堆棧時(shí),釋放malloc分配的空間。注意:免費(fèi)(s->base)是可以的。如果循環(huán)釋放free(s->base),將報(bào)告錯(cuò)誤。原因:基址沒有指向malloc分配的地址。
6. difference&*&是地址符號(hào),*是內(nèi)容符號(hào)。在指針中,這兩個(gè)符號(hào)非常重要。當(dāng)我們需要更改函數(shù)的外部參數(shù)的值時(shí),我們需要傳入變量的地址而不是值。例如,如果我需要更改int a的值,我需要這樣寫:通過這種方式,我可以理解為什么在前面的函數(shù)中直接使用stack*s而不是stack s,因?yàn)橹苯觽鬟f的s不能更改s中元素的值。
7。區(qū)分->和。在C語(yǔ)言中->前面是指針和。前面是結(jié)構(gòu)變量。因此,當(dāng)函數(shù)傳入結(jié)構(gòu)指針時(shí)使用s->len,當(dāng)函數(shù)傳入結(jié)構(gòu)變量時(shí)使用s.len。
計(jì)算機(jī)專業(yè)的學(xué)生需要深入學(xué)習(xí)C語(yǔ)言嗎?
計(jì)算機(jī)專業(yè)的學(xué)生應(yīng)該學(xué)習(xí)編程語(yǔ)言,如C語(yǔ)言。不管是C語(yǔ)言還是其他編程語(yǔ)言,它只是一個(gè)工具,一個(gè)其他課程的編程工具。具體情況如下。
計(jì)算機(jī)專業(yè)可能要學(xué)習(xí)多種編程語(yǔ)言,有些學(xué)生覺得有點(diǎn)難。其實(shí)不用擔(dān)心,編程語(yǔ)言之間有很多相似之處,認(rèn)真學(xué)習(xí)C語(yǔ)言,其他編程語(yǔ)言都可以快速入門。
例如,C語(yǔ)言的基本數(shù)據(jù)類型是整數(shù)、字符等,復(fù)雜點(diǎn)的數(shù)據(jù)類型是數(shù)組和結(jié)構(gòu)。在C和Java中,基本數(shù)據(jù)類型和復(fù)雜數(shù)據(jù)類型也是如此。所以學(xué)習(xí)C語(yǔ)言,其他語(yǔ)言也要學(xué)習(xí)一半以上。
例如,有一門名為“數(shù)據(jù)結(jié)構(gòu)”的課程,重點(diǎn)介紹各種復(fù)雜的數(shù)據(jù)類型和算法。例如堆棧、隊(duì)列、二叉樹等數(shù)據(jù)結(jié)構(gòu),以及二叉搜索、樹遍歷、圖搜索等算法。學(xué)好這些數(shù)據(jù)結(jié)構(gòu)和算法只意味著您理解這些概念,但您必須使用編程語(yǔ)言來使用它們。
現(xiàn)在有數(shù)據(jù)結(jié)構(gòu)教材用C語(yǔ)言來實(shí)現(xiàn)吧!例如用C語(yǔ)言實(shí)現(xiàn)鏈表、隊(duì)列、二叉樹等數(shù)據(jù)結(jié)構(gòu),用C語(yǔ)言實(shí)現(xiàn)堆排序、快速排序等算法。
所以學(xué)習(xí)C語(yǔ)言不是為了學(xué)習(xí),而是為了學(xué)習(xí)其他課程,或者是為了解決未來生活和工作中的問題。因此,C語(yǔ)言是非常重要的!