當前位置:首頁 > 公眾號精選 > 嵌入式微處理器
[導讀]算法太重要了!“人工智能”,“機器學習”,“大數據”,這些越來越常聽到的字眼,背后其實都是一個個“算法”。諸多高新科技,似乎都離不開“算法”的“加持”。

算法太重要了

人工智能”,“機器學習”,“大數據”,這些越來越常聽到的字眼,背后其實都是一個個“算法”。
諸多高新科技,似乎都離不開“算法”的“加持”。
科學家 / 工程師 / 技術人員,現在如果不懂點算法,都不太好意思了。
算法其實很容易
聽著這么高大上的“算法”其實一點也不難學!
為啥講算法的書卻很難看懂?
就是講得太復雜了么,不同編程語言還都不一樣。
什么是“算法”
算法,一看字面就知道,肯定是“計算方法”的簡稱啦,特指“計算機的計算方法”,所以,算法是由電腦程序來實現的。
算法,英文叫Algorithm,就是為了讓電腦解決一個問題而設計出來的一套計算方法,這套計算方法的設計是依靠“數學模型”的建立。
也就是說,程序員在設計算法之前,會將實際問題理解分析,歸納為一個“具體的數學問題”。


算法是解決問題的計算方法
算法有這么幾個特征
1?確定
算法的每一個步驟都有“明確的意義”,對于算法結果的預期也是明確的。
2?有窮
算法不能一直算,停不下來是不行的;要有一個明確的結束條件,要不然算到“天荒地老”還有什么意義呢?
3?可行
有個笑話說一個人面試會計師,算數特別快瞬間出結果,但是就是算得不對。
4?輸入輸出
算法就是用來解決問題的,問題的來源就是輸入,問題的結果就是輸出。


再復雜的算法也是由一個個小算法組合成的

怎么設計一個算法程序呢

算法有三個要素——
數學模型,輸入輸出方法,算法步驟。


所以說,怎么設計一個算法呢?
首先,先對要解決的問題建立一個數學模型,把原問題化為數學問題;
然后,將問題的“已知條件”化為“數據”輸入到數學模型中;
再然后,通過對輸入一步一步的轉化/處理/計算,得到結果;
最后,把結果按照希望的形式,輸出出來。

舉個例子吧

比如我們要解決一個問題——班級里有30個同學,我們現在知道他們的姓名和考試分數,比如小紅90分,小剛97分,小明60分等等,求班級里面哪位同學成績最好?


誰的成績最好呢?
那么我們按照上面的步驟來設計一個小算法吧。
1?把原問題轉化為數學問題
求30個成績值中的最大值及對應的姓名;
2?已知條件化為輸入數據
依次輸入30個名字和30個成績值;(其中名字的數據類型為字符串,成績值的數據類型為整數型,關于數據類型我們將在后面詳細講解)
3?分步計算
這是一個典型的求最大值的問題,方法很多,這里舉一種方法:
3-1 取出第1個同學和第2個同學的姓名和成績,比較大小,將那個較大的成績值儲存在一個位置,這個位置我們給他起個名字,就叫<當前最大成績值>吧,再把這個較好的成績對應的同學姓名存到另一個位置,就叫<當前最好成績的同學姓名>;
3-2 這樣,第1個同學和第2個同學成績比較完成,得到了這2名同學中的成績最好的同學,信息儲存在:<當前最大成績值>和<當前最好成績的同學姓名>中;
3-3?下面就是重復性的工作了,把得到的<當前最大成績值>和<當前最好成績的同學姓名>與第3位同學進行比較,仍然是把較大的成績值儲存在<當前最大成績值>里,把這個較好的成績對應的同學姓名存到<當前最好成績的同學姓名>里;
3-4 這個過程一直進行,直到把30個同學的信息都比較完,這時<當前最大成績值>里存的值就是最好的成績,<當前最好成績的同學姓名>里存的值就是這位最厲害的同學的姓名。
4?輸出
按照你想要的格式,將上面兩個儲存的值顯示出來,就完成了!

借上面的例子有幾點要說明一下

1?解決同一個問題,可能有各種各樣的算法。不同的算法,可能執(zhí)行速度不同,可能編寫難易度不同,可能占用的資源不同,甚至可能計算準確度都不同;很多時候并沒有最好的算法,只有在特定條件下最適合的算法
2?每一個算法都有適用的條件,條件變了,算法可能就用好用了。比如上面例子,如果這個班級中有2個同學的成績剛好一樣,那么按理說就應該輸出兩個姓名和成績,上面的算法就需要改進一下了。


算法 —— 一個強邏輯體
3?能把問題具體化為一個或幾個數學問題,問題就解決了一半。就如同學習和工作中一樣,所謂解決問題的能力,有一半是分析問題的能力,能夠將大問題分解成小問題,將抽象問題等價為具體問題。
作者|科技千里眼
來源|https://www.toutiao.com/a6616930406409175556/
-?END -

【1】國內MCU能替代國外產品嗎?MCU的未來又將如何?

【2】35歲真的是程序員的坎兒嗎?

【3】不同編程語言能耗不同?看這27種語言對比!

【4】超長干貨為你解析:從串口驅動到Linux驅動模型,嵌入式必會!

【5】本文把TCP/IP講絕了!




免責聲明:本文內容由21ic獲得授權后發(fā)布,版權歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯系我們,謝謝!

嵌入式ARM

掃描二維碼,關注更多精彩內容

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯系該專欄作者,如若文章內容侵犯您的權益,請及時聯系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或將催生出更大的獨角獸公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數字化轉型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據媒體報道,騰訊和網易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數據產業(yè)博覽會開幕式在貴陽舉行,華為董事、質量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數據產業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經營業(yè)績穩(wěn)中有升 落實提質增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數字經濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯合牽頭組建的NVI技術創(chuàng)新聯盟在BIRTV2024超高清全產業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現場 NVI技術創(chuàng)新聯...

關鍵字: VI 傳輸協議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉