C++超詳細(xì)分析順序表
本次我們解剖順序表將從以下三個(gè)結(jié)構(gòu):
1、靜態(tài)順序表和動(dòng)態(tài)順序表
2、順序表實(shí)現(xiàn)增刪查改等常見接口
3、順序表相關(guān)OJ題練習(xí)
什么是順序表
順序表是用一段物理地址連續(xù)的存儲(chǔ)單元依次存儲(chǔ)數(shù)據(jù)元素的線性結(jié)構(gòu),一般情況下采用數(shù)組存 儲(chǔ)。在數(shù)組上完成數(shù)據(jù)的增刪查改。
兄弟們兄弟們,記得摳字眼啊,順序表一定是連續(xù)的存儲(chǔ)單元,并且是依次存儲(chǔ)數(shù)據(jù)的?。。?!
順序表一般可以分為:
? 靜態(tài)順序表 ?? 動(dòng)態(tài)順序表
靜態(tài)順序表:使用定長(zhǎng)數(shù)組存儲(chǔ),簡(jiǎn)單來說大小是固定的,數(shù)據(jù)個(gè)數(shù)也是固定的!
動(dòng)態(tài)順序表:使用動(dòng)態(tài)開辟的數(shù)組存儲(chǔ),簡(jiǎn)單來說,裝滿了會(huì)自動(dòng)擴(kuò)大容量!
靜態(tài)順序表的實(shí)現(xiàn)我們就不講了,冬天到了春天還會(huì)遠(yuǎn)嗎?會(huì)了動(dòng)態(tài)你還不會(huì)靜態(tài)嗎?所以我們今天主要講動(dòng)態(tài)順序表!靜態(tài)順序表搭建代碼如下:
// 順序表的靜態(tài)存儲(chǔ) #define N 100 typedef int SLDataType; typedef struct SeqList { SLDataType array[N]; // 定長(zhǎng)數(shù)組 size_t size; // 有效數(shù)據(jù)的個(gè)數(shù) }SeqList;
動(dòng)態(tài)順序表
?? 來到今天的重點(diǎn)!動(dòng)態(tài)順序表!
首先先來搭建順序表的結(jié)構(gòu)。
?? 上面就是我給大家畫的基本一個(gè)結(jié)構(gòu)圖了,下面我們來實(shí)現(xiàn)順序表的基本接口:
?? 首先我們順序表需要初始化:
?? 既然我們沒有在初始化給定大小,我們現(xiàn)在要判斷需不需要給動(dòng)態(tài)表順序表增容:
?? 我們來實(shí)現(xiàn)動(dòng)態(tài)順序表頭部插入數(shù)據(jù):
?? 接著來實(shí)現(xiàn)尾部插入數(shù)據(jù):
?? 我們要開始實(shí)現(xiàn)頭部刪除數(shù)據(jù)了:
?? 下面實(shí)現(xiàn)尾部刪除數(shù)據(jù):
?? 接著我們來實(shí)現(xiàn)在pos下標(biāo)位置插入數(shù)據(jù):
?? 我們?cè)賮韺?shí)現(xiàn)刪除pos下標(biāo)位置的數(shù)據(jù):
? 查找順序表中的元素x:
?? 修改指定pos下標(biāo)的數(shù)據(jù)
在實(shí)際中在我上面寫的函數(shù)有些都可以復(fù)用哦!這個(gè)就等著你們?nèi)グl(fā)現(xiàn)吧,我們接著往下走:
其實(shí)還有一些順序表的打印,清空,求元素個(gè)數(shù),這些相信你們看完上面的內(nèi)容對(duì)于你們來說非常容易!我就不一一舉例了,下面進(jìn)入我們的習(xí)題時(shí)間!(●'?'●)
題目1:給你一個(gè)數(shù)組 nums 和一個(gè)值 val,你需要原地移除所有數(shù)值等于 val 的元素,并返回移除后數(shù)組的新長(zhǎng)度。不要使用額外的數(shù)組空間,你必須僅使用 O(1) 額外空間并原地修改輸入數(shù)組。元素的順序可以改變。你不需要考慮數(shù)組中超出新長(zhǎng)度后面的元素。
示例 1:
輸入:nums = [0,1,2,2,3,0,4,2], val = 2
輸出:5, nums = [0,1,4,0,3]
解釋:函數(shù)應(yīng)該返回新的長(zhǎng)度 5, 并且 nums 中的前五個(gè)元素為 0, 1, 3, 0, 4。注意這五個(gè)元素可為任意順序。你不需要考慮數(shù)組中超出新長(zhǎng)度后面的元素。
題目來源:27. 移除元素 - 力扣(LeetCode) (leetcode-cn.com)
思路1:遍歷數(shù)組,發(fā)現(xiàn)元素為val就把后面的往前挪覆蓋掉val,但是這樣的時(shí)間復(fù)雜度為O(N²),這樣當(dāng)數(shù)組全是val,效率就會(huì)特別低!
思路2:以空間換時(shí)間,開辟一個(gè)新數(shù)組,把不是val的數(shù)放到新數(shù)組,再把新數(shù)組的值拷貝回來!但是這樣的話空間復(fù)雜度O(N)不符合題意!
思路3:使用雙指針,空間復(fù)雜度O(1),時(shí)間復(fù)雜度O(n),代碼如下:
int removeElement(int* nums, int numsSize, int val) { int src = 0; int dst = 0; while (src < numsSize) { if (nums[src] != val) { nums[dst++] = nums[src++]; } else { ++src; } } return dst; }
題目2:給你兩個(gè)按非遞減順序排列的整數(shù)數(shù)組 nums1 和 nums2,另有兩個(gè)整數(shù) m 和 n ,分別表示 nums1 和 nums2 中的元素?cái)?shù)目。請(qǐng)你 合并 nums2 到 nums1 中,使合并后的數(shù)組同樣按非遞減順序排列。
示例 1:
輸入:nums1 = [1,2,3,0,0,0], m = 3, nums2 = [2,5,6], n = 3
輸出:[1,2,2,3,5,6]
解釋:需要合并 [1,2,3] 和 [2,5,6] 。
合并結(jié)果是 [1,2,2,3,5,6] ,其中斜體加粗標(biāo)注的為 nums1 中的元素。
題目來源:88. 合并兩個(gè)有序數(shù)組 - 力扣(LeetCode) (leetcode-cn.com)
那這道題的思路就留給小伙伴們自己去思考了,我就直接給你們上代碼!
void merge(int* nums1, int m, int* nums2, int n) { int end1 = m - 1; int end2 = n - 1; int end = m + n - 1; while (end1 >= 0 && end2 >= 0) { if (nums1[end1] > nums2[end2]) { nums1[end] = nums1[end1]; --end; --end1; } else { nums1[end] = nums2[end2]; --end; --end2; } } //如果是end2結(jié)束,不需要處理因?yàn)榫褪窃趎ums1里面 while (end2 >= 0) { nums1[end] = nums2[end2]; --end; --end2; } }
好了,通過這篇文章的學(xué)習(xí),相信你會(huì)把順序表理解的更透徹,還是那句話,我們一起快樂編程不頭禿!加油奧里給!??????
????????????完結(jié)撒花!????????????
gitee(碼云):Mercury. (zzwlwp) - Gitee.com
到此這篇關(guān)于C++超詳細(xì)分析順序表的文章就介紹到這了,更多相關(guān)C++ 順序表內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++實(shí)現(xiàn)簡(jiǎn)單通訊錄管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)簡(jiǎn)單通訊錄管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02jQuery移動(dòng)頁(yè)面開發(fā)中主題按鈕的設(shè)計(jì)示例
這篇文章主要介紹了jQuery移動(dòng)頁(yè)面開發(fā)中主題按鈕的設(shè)計(jì)示例,jQuery是當(dāng)今最具人氣的JavaScript開發(fā)類庫(kù),需要的朋友可以參考下2015-12-12針對(duì)Ruby的Selenium WebDriver安裝指南
這篇文章主要介紹了針對(duì)Ruby的Selenium WebDriver安裝指南,Selenium直接運(yùn)行于瀏覽器之中,是進(jìn)行各種調(diào)試的一大神器,需要的朋友可以參考下2015-07-07C語言回調(diào)函數(shù)的簡(jiǎn)單運(yùn)用
回調(diào)函數(shù)就是函數(shù)指針變量作為另外一個(gè)函數(shù)的參數(shù)而使用的一種應(yīng)用情形。本文就詳細(xì)的介紹一下C語言回調(diào)函數(shù)的簡(jiǎn)單運(yùn)用,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-09-09