c++棧的實(shí)現(xiàn) 為什么剛?cè)腴T(mén)的程序員沒(méi)有感覺(jué)到算法和數(shù)據(jù)結(jié)構(gòu)的重要性?
為什么剛?cè)腴T(mén)的程序員沒(méi)有感覺(jué)到算法和數(shù)據(jù)結(jié)構(gòu)的重要性?關(guān)于這個(gè)問(wèn)題,首先,我非常遺憾地告訴你兩點(diǎn)。首先,能夠問(wèn)這個(gè)問(wèn)題意味著你不是一個(gè)程序員。只能說(shuō)你才剛剛開(kāi)始學(xué)習(xí)編程(即使你有一份編程工作,你也不能
為什么剛?cè)腴T(mén)的程序員沒(méi)有感覺(jué)到算法和數(shù)據(jù)結(jié)構(gòu)的重要性?
關(guān)于這個(gè)問(wèn)題,首先,我非常遺憾地告訴你兩點(diǎn)。
首先,能夠問(wèn)這個(gè)問(wèn)題意味著你不是一個(gè)程序員。只能說(shuō)你才剛剛開(kāi)始學(xué)習(xí)編程(即使你有一份編程工作,你也不能改變這一點(diǎn))。就像說(shuō)一個(gè)剛學(xué)了三個(gè)月吉他的人不能稱自己為吉他手(但他可以說(shuō)是吉他手或吉他手)。
其次,我很抱歉地告訴你,你還沒(méi)有開(kāi)始。入門(mén)的先決條件之一是理解程序?qū)嶋H上是一個(gè)算法數(shù)據(jù)結(jié)構(gòu)。所以你說(shuō)你是一個(gè)入門(mén)級(jí)程序員,但你不覺(jué)得算法和數(shù)據(jù)結(jié)構(gòu)的重要性。那么我想問(wèn)一下,除了算法和數(shù)據(jù)結(jié)構(gòu)之外,程序中還有什么重要的東西。
不理解狹義的算法,認(rèn)為算法是排序算法、搜索算法,認(rèn)為數(shù)據(jù)結(jié)構(gòu)是數(shù)組、鏈表、哈希表、圖形等。這些都是經(jīng)典的算法和數(shù)據(jù)結(jié)構(gòu)。
你寫(xiě)的程序,不能有任何這些經(jīng)典的數(shù)據(jù)結(jié)構(gòu)和算法,那么,你的程序沒(méi)有算法和數(shù)據(jù)結(jié)構(gòu)嗎?你的程序必須解決一個(gè)問(wèn)題或做些什么。這些東西,你首先需要在計(jì)算機(jī)世界建立一個(gè)模型,這個(gè)模型就是數(shù)據(jù)結(jié)構(gòu)?;谶@些數(shù)據(jù),您的程序需要執(zhí)行一些指令,這些指令是作為一個(gè)整體的算法。因此,program=algorithm數(shù)據(jù)結(jié)構(gòu)就是在這個(gè)廣義上說(shuō)的。
正是因?yàn)椤俺绦?算法數(shù)據(jù)結(jié)構(gòu)”,所以沒(méi)有了算法和數(shù)據(jù)結(jié)構(gòu),程序中就沒(méi)有殘留。至于算法和數(shù)據(jù)結(jié)構(gòu)之間的關(guān)系,我不在這里討論。總之,沒(méi)有數(shù)據(jù),算法就沒(méi)有對(duì)象和基礎(chǔ)。數(shù)據(jù)結(jié)構(gòu)的設(shè)計(jì)和合理性將影響算法的性能。
為什么你感覺(jué)不到?答案是我答案開(kāi)頭的兩點(diǎn)。我說(shuō)的話似乎有點(diǎn)殘忍,但實(shí)際上沒(méi)什么。繼續(xù)學(xué)習(xí)。
程序員需要終身學(xué)習(xí)。
學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)和算法有哪些入門(mén)的書(shū)籍資料?
你應(yīng)該先學(xué)習(xí)離散數(shù)學(xué)。算法基礎(chǔ)打開(kāi)了算法,算法第四版,算法介紹,最后由GaDENER的計(jì)算機(jī)編程藝術(shù)的幾卷門(mén)
!對(duì)于數(shù)據(jù)結(jié)構(gòu)和算法,它們實(shí)際上是一個(gè)抽象的東西,不綁定到某種語(yǔ)言。換句話說(shuō),數(shù)據(jù)結(jié)構(gòu)和算法可以理解為數(shù)據(jù)域。因此,幾乎所有語(yǔ)言都支持相同的數(shù)據(jù)結(jié)構(gòu)和算法。
例如,通用數(shù)據(jù)結(jié)構(gòu),如數(shù)組、鏈表、堆棧、隊(duì)列和樹(shù),可以用每種語(yǔ)言實(shí)現(xiàn),但實(shí)現(xiàn)細(xì)節(jié)可能不同。以鏈表為例,在C語(yǔ)言中通常是以指針的形式實(shí)現(xiàn)的,而Python中沒(méi)有指針的概念,但是可以用其他的方式實(shí)現(xiàn)。
算法與語(yǔ)言無(wú)關(guān)。算法只是一些數(shù)據(jù)處理邏輯,所以它可以用任何語(yǔ)言實(shí)現(xiàn)。如果語(yǔ)言不能實(shí)現(xiàn)某些邏輯,那么顯然就有問(wèn)題了。
一般來(lái)說(shuō),數(shù)據(jù)結(jié)構(gòu)和算法與語(yǔ)言無(wú)關(guān)。但是,除了數(shù)據(jù)結(jié)構(gòu)外,還存在數(shù)據(jù)類型的概念,如整數(shù)、字符、浮點(diǎn)等。這些內(nèi)容在不同語(yǔ)言中的實(shí)現(xiàn)可能不同。