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

C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)與算法之時(shí)間空間復(fù)雜度入門

 更新時(shí)間:2022年02月15日 12:24:08   作者:?jiǎn)虇碳业凝堼? 
這篇文章主要為大家介紹了C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)與算法之時(shí)間空間復(fù)雜度的入門教程示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步

數(shù)據(jù)結(jié)構(gòu)與算法

終于開始搞這塊難啃的骨頭了,走上這條漫漫長(zhǎng)路之前要明白:

什么是數(shù)據(jù)結(jié)構(gòu)?什么是算法?

是數(shù)據(jù)之間存在一種或多種特定關(guān)系的數(shù)據(jù)元素集合,為編寫出一個(gè)“好”的程序,必須分析待處理對(duì)象的特性及各處理對(duì)象之間存在的關(guān)系,這也就是研究數(shù)據(jù)結(jié)構(gòu)的意義所在為編寫出一個(gè)“好”的程序,必須分析待處理對(duì)象的特性及各處理對(duì)象之間存在的關(guān)系這也就是研究數(shù)據(jù)結(jié)構(gòu)的意義所在

算法是解決特定問題求解步驟的描述,在計(jì)算機(jī)中表現(xiàn)為指令的有限序列 ,并且每條指令表示一個(gè)或多個(gè)操作

拋開上面的學(xué)術(shù)性口水話,簡(jiǎn)單來說就是:

1.數(shù)據(jù)結(jié)構(gòu)是計(jì)算機(jī)存儲(chǔ),組織數(shù)據(jù)的方式

2.算法是一系列規(guī)定的計(jì)算步驟,為了實(shí)現(xiàn)的特定的計(jì)算目的而應(yīng)用

給個(gè)更直觀的視圖就是:算法+數(shù)據(jù)結(jié)構(gòu)就等于程序,數(shù)據(jù)結(jié)構(gòu)可以理解為實(shí)現(xiàn)一個(gè)程序的基本單位,算法可以看作一個(gè)加工過程。

比如我去從一個(gè)很大的數(shù)組里面提取某個(gè)特定的對(duì)象,我們既可以老老實(shí)實(shí)從頭到尾遍歷查找,也就是所謂的暴力搜索,工程量隨著數(shù)組的容量增大而增大;我們也可以巧奪智取,用二分查找讓我們工作事半功倍。

分析維度

在知道基本概念后,我們說在拿到一個(gè)算法后,我們?cè)趺慈タ此暮脡??或者給你多個(gè)算法,他們都實(shí)現(xiàn)同一個(gè)功能,我們?cè)趺慈ヅ袛嗨膬?yōu)缺點(diǎn)去取舍呢?正常情況下,我們會(huì)選擇把這個(gè)代碼放在某個(gè)環(huán)境下運(yùn)行比較時(shí)間,但這個(gè)做法有一個(gè)致命的缺點(diǎn),在我們不同機(jī)器上,會(huì)有不同的結(jié)果,在好的機(jī)器上,運(yùn)行時(shí)間會(huì)很短,但是在比較差一點(diǎn)的主機(jī)上,就稍有遜色,這樣一來就有失公平。

大O的漸進(jìn)表示法

不要直接計(jì)算時(shí)間,,我們需要去計(jì)算一個(gè)漸進(jìn)的時(shí)間復(fù)雜度,也就是所謂的Big O (大O表示法),他其實(shí)本質(zhì)上實(shí)在求一個(gè)量級(jí)(時(shí)間)在增加時(shí)的一個(gè)變化趨勢(shì)

時(shí)間復(fù)雜度公式:T(n)=O(f(n))

T(n):時(shí)間頻度(執(zhí)行次數(shù))
n :?jiǎn)栴}規(guī)模;
f(n):T(n)的同數(shù)量級(jí)函數(shù);
O :代表正比例關(guān)系;
O(f(n)):即算法的漸進(jìn)時(shí)間復(fù)雜度

常數(shù)階

我們的算加法的完整過程:

int main()
{
int a = 1;
int b = 1;
int sum = a+b;
printf("%d",sum);
}

我們每走一步就會(huì)執(zhí)行一次,上面的代碼我就執(zhí)行了四次;那么如果我把他的sum部分重復(fù)執(zhí)行數(shù)十次數(shù)百次數(shù)千次,但他本質(zhì)上和執(zhí)行四次沒有區(qū)別,執(zhí)行時(shí)間是恒定的,這個(gè)層面上,他的時(shí)間復(fù)雜度就是O(1)(常數(shù)階)。

不管這個(gè)常數(shù)是多少,4或∞,都不能寫成O(4)、O(∞),都要寫成O(1)

線性階

我們給出一個(gè) for loop

for(int a = 1;a<=n;a++)
{
 a++;
}

分析線性階時(shí)會(huì)比常數(shù)階更復(fù)雜因?yàn)橐治鏊难h(huán)結(jié)構(gòu),上面的代碼限制再++,總共執(zhí)行3次,包括常數(shù)階的賦值就是O(3n+1),在我的n足夠大時(shí)他會(huì)無(wú)限接近于無(wú)窮,這時(shí)的+1就會(huì)沒有意義。

這時(shí)就順理成章,嵌套循環(huán)我們也就可以理解了,兩層 for 就是O(n2),三層就是O(n2)for 下面加一個(gè)雙層for循環(huán)就是O(n+n2)……這里面就包含了**平方階**;此時(shí)我O(n)的效率就比O(n2)高。

對(duì)數(shù)階

我們?cè)俳o出一個(gè)while loop

int n = 0;
while(n<100000)
{
n*=2;
}

我們要看執(zhí)行次數(shù)就要看多少步才能走出循環(huán),就意味著要乘 x 個(gè)2能>=10000,則表示為 2^x =100000,假設(shè)為隨機(jī)數(shù) a,則 x= log 2 ^a,
復(fù)雜度為O(logn)

除了上面三種之外還有其他的復(fù)雜度

在這里插入圖片描述

從常數(shù)階到階乘是越來越復(fù)雜,我們看一下直觀數(shù)據(jù):

在這里插入圖片描述

這里橫軸是輸入(input)量級(jí),縱軸是消耗時(shí)間也就是時(shí)間復(fù)雜度,也就是有個(gè)很直觀的信息:算法復(fù)雜度越高,需要的時(shí)間越長(zhǎng),到后面就直接指數(shù)級(jí)增長(zhǎng)。

其他時(shí)間復(fù)雜度指標(biāo)

雖然有下面這些種吧,但我們主要會(huì)把重心放在 O 上,畢竟它是最常用的指標(biāo)。

在這里插入圖片描述

空間復(fù)雜度

空間復(fù)雜度是指內(nèi)存空間增長(zhǎng)的趨勢(shì),相對(duì)就容易理解一些,O(1)就是相當(dāng)于單次賦值,而 O(n)相當(dāng)于賦值n次,可以把他想成一個(gè)大小為 n 的數(shù)組,復(fù)雜度越高需要分配的空間就越多;同理,O(n^2)就可以想成一個(gè)n行n列的二維數(shù)組。

今天就到這里吧,摸了家人們,更多關(guān)于C語(yǔ)言數(shù)據(jù)結(jié)構(gòu)與算法時(shí)間空間復(fù)雜度的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 基于c++11的event-driven library的理解

    基于c++11的event-driven library的理解

    這篇文章主要介紹了基于c++11的event-driven library的理解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • C++中signed?main和int?main的區(qū)別

    C++中signed?main和int?main的區(qū)別

    這篇文章介紹了C++中signed?main和int?main的區(qū)別,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-12-12
  • C++ AfxBeginThread的介紹/基本用法

    C++ AfxBeginThread的介紹/基本用法

    這篇文章主要簡(jiǎn)單介紹了C++ AfxBeginThread的基本用法,十分的細(xì)致,有需要的小伙伴可以參考下。
    2015-06-06
  • C語(yǔ)言示例講解while循環(huán)語(yǔ)句的用法

    C語(yǔ)言示例講解while循環(huán)語(yǔ)句的用法

    在不少實(shí)際問題中有許多具有規(guī)律性的重復(fù)操作,因此在程序中就需要重復(fù)執(zhí)行某些語(yǔ)句。一組被重復(fù)執(zhí)行的語(yǔ)句稱之為循環(huán)體,C語(yǔ)言while語(yǔ)句可以是單個(gè)語(yǔ)句,也可以是一個(gè)語(yǔ)句塊,其條件可以是任意表達(dá)式,true是任意非零值,當(dāng)條件為真時(shí),循環(huán)進(jìn)行迭代
    2022-06-06
  • C++智能指針詳解

    C++智能指針詳解

    從比較簡(jiǎn)單的層面來看,智能指針是RAII(Resource Acquisition Is Initialization,資源獲取即初始化)機(jī)制對(duì)普通指針進(jìn)行的一層封裝。這樣使得智能指針的行為動(dòng)作像一個(gè)指針,本質(zhì)上卻是一個(gè)對(duì)象,這樣可以方便管理一個(gè)對(duì)象的生命周期
    2022-08-08
  • C++設(shè)置事件通知線程工作的方法

    C++設(shè)置事件通知線程工作的方法

    這篇文章主要介紹了C++設(shè)置事件通知線程工作的方法,是Windows應(yīng)用程序設(shè)計(jì)中非常實(shí)用的技巧,需要的朋友可以參考下
    2014-10-10
  • Qt實(shí)戰(zhàn)案例之如何利用QProcess類實(shí)現(xiàn)啟動(dòng)進(jìn)程

    Qt實(shí)戰(zhàn)案例之如何利用QProcess類實(shí)現(xiàn)啟動(dòng)進(jìn)程

    這篇文章主要介紹了Qt實(shí)戰(zhàn)案例之如何利用QProcess類實(shí)現(xiàn)啟動(dòng)進(jìn)程,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-02-02
  • EasyC++內(nèi)部鏈接性和無(wú)鏈接性

    EasyC++內(nèi)部鏈接性和無(wú)鏈接性

    這篇文章主要介紹了EasyC++內(nèi)部鏈接性和無(wú)鏈接性,當(dāng)我們使用static關(guān)鍵字,將變量的作用于限制在整個(gè)文件時(shí),該變量的鏈接性為內(nèi)部鏈接性,然而無(wú)鏈接性的變量其實(shí)就是在代碼塊當(dāng)中使用static關(guān)鍵字創(chuàng)建的,接下來一起進(jìn)入文章了解更多內(nèi)容吧
    2021-12-12
  • C++實(shí)現(xiàn)求動(dòng)態(tài)矩陣各元素的和

    C++實(shí)現(xiàn)求動(dòng)態(tài)矩陣各元素的和

    這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)求動(dòng)態(tài)矩陣各元素的和,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • C語(yǔ)言模擬實(shí)現(xiàn)strstr函數(shù)的示例代碼

    C語(yǔ)言模擬實(shí)現(xiàn)strstr函數(shù)的示例代碼

    strstr是C語(yǔ)言中的函數(shù),作用是返回字符串中首次出現(xiàn)子串的地址。本文將用C語(yǔ)言模擬實(shí)現(xiàn)strstr函數(shù),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2022-07-07

最新評(píng)論