找零錢問題

最近在做華為機試體驗題,遇到一個“找零錢”的題目,如下

想起之前在牛客網上看到左程云老師講過的動態規劃問題,很像,題目如下:

有數組penny,penny中所有的值都為正數且不重復。每個值代表一種面值的貨幣,每種面值的貨幣可以使用任意張,再給定一個整數aim(小于等于1000)代表要找的錢數,求換錢有多少種方法。

給定數組penny及它的大小(小于等于50),同時給定一個整數aim,請返回有多少種方法可以湊成aim。


用Java編程實現:

public class DynamicProgramming {public int countWays(int[] penny, int n, int aim) {int[][] dp = new int[n][aim + 1];// 定義一個矩陣,dp[i][j]表示用penny[0...i-1]個貨幣組成j的錢數if (penny.length == 0 || aim < 0)return 0;for (int i = 0; i < n; i++) {dp[i][0] = 1;// 第一列全是1}for (int i = 0; i < aim + 1; i++)dp[0][i] = (i % penny[0] == 0) ? 1 : 0;// 第一行中是i的倍數的則為1for (int i = 1; i < n; i++) {for (int j = 1; j < aim + 1; j++) {if (j >= penny[i]) {dp[i][j] = dp[i - 1][j] + dp[i][j - penny[i]];} else {dp[i][j] = dp[i - 1][j];}}}return dp[n - 1][aim];}//以下是自己添加的測試用例,在牛客網上不需要輸入(它自帶測試用例)public static void main(String[] args) {int[] penny = { 1, 3, 4 };int n = penny.length;int aim = 3;DynamicProgramming dynamicProgramming = new DynamicProgramming();System.out.println(dynamicProgramming.countWays(penny, n, aim));}
}

輸出:3


關于動態規劃,啰嗦一句,先看懂暴力搜索,動態規劃就不難理解。


課程參考地址:http://www.nowcoder.com/courses/1?coupon=AO79vdy ?

優惠碼:AO79vdy

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/385993.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/385993.shtml
英文地址,請注明出處:http://en.pswp.cn/news/385993.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

vga焊接線順序_焊接工藝問答,不做焊接也要收藏起來

點 機械前沿”關注置頂引領機械前沿、機械視頻&#xff0c;汽車、加工技術、3D打印、自動化、機器人、生產工藝、軸承、模具、機床、鈑金等行業前沿在這里等你 焊接工藝問答1.什么叫焊接條件&#xff1f;它有哪些內容&#xff1f;?答&#xff1a;焊…

7年老Android一次操蛋的面試經歷,揮淚整理面經

看到還有很多程序員連面試流程都沒有徹底弄清楚&#xff0c;今天&#xff0c;我們以阿里為例&#xff0c;來聊聊互聯網大廠的面試流程和過程&#xff01; 本篇主要還是聊聊社招的面試過程&#xff01;阿里以及其他的互聯網大廠的技術類社招面試&#xff0c;通常情況是 4 個輪次…

gin context和官方context_Go Web 小技巧(一)簡化Gin接口代碼

不知道大家在使用 Gin 構建 API 服務時有沒有這樣的問題:參數綁定的環節可不可以自動處理&#xff1f;錯誤可不可以直接返回&#xff0c;不想寫空 return, 漏寫就是 bug本文通過簡單地封裝&#xff0c;利用 go 的接口特性&#xff0c;提供一個解決上述兩個問題的思路一、解決過…

7年老Android一次操蛋的面試經歷,深度好文

Java基礎 Java Object類方法HashMap原理&#xff0c;Hash沖突&#xff0c;并發集合&#xff0c;線程安全集合及實現原理HashMap 和 HashTable 區別HashCode 作用&#xff0c;如何重載hashCode方法ArrayList與LinkList區別與聯系GC機制Java反射機制&#xff0c;Java代理模式Jav…

Hadoop大數據應用生態圈中最主要的組件及其關系

Hadoop Common Hadoop Common是在Hadoop0.2版本之后分離出來的HDFS和MapReduce獨立子項目的內容&#xff0c;是Hadoop的核心部分&#xff0c;能為其他模塊提供一些常用工具集&#xff0c;如序列化機制、Hadoop抽象文件系統FileSystem、系統配置工具Configuration&#xff0c;并…

7年老Android一次操蛋的面試經歷,系列教學

公司的需求 不同的公司&#xff0c;不同的需求現在的市場上&#xff0c;公司很多&#xff0c;大致上可以歸納為兩個大類&#xff1a;大公司和小公司&#xff0c;他們招聘時對人才的需求也不一樣。 小公司 小公司他們一般急需的是能夠投入工作的人才&#xff0c;因為公司規模…

丁香園 武漢 神童_杭州、武漢、成都哪個城市更適合程序員發展

很多朋友討論起房價和職業發展機會&#xff0c;都會提到這三個城市&#xff0c;有的人認為目前杭州房價太貴了&#xff0c;生活成本高&#xff0c;華中的武漢和西部崛起的成都都在鼓勵高新技術發展并且有了一定成果&#xff0c;在選擇職業發展和定居城市之間該如何取舍呢&#…

Windows 7 64位系統上搭建Hadoop偽分布式環境(很詳細)

在開始配置前&#xff0c;我們先了解Hadoop的三種運行模式。 Hadoop的三種運行模式 獨立&#xff08;或本地&#xff09;模式&#xff1a;無需運行任何守護進程&#xff0c;所有程序都在同一個JVM上執行。在獨立模式下測試和調試MapReduce程序很方便&#xff0c;因此該模式在…

7年老Android一次操蛋的面試經歷,講的太透徹了

由于涉及到的面試題較多導致篇幅較長&#xff0c;我根據這些面試題所涉及到的常問范圍總結了并做出了一份學習進階路線圖???????及面試題答案免費分享給大家&#xff0c;文末有免費領取方式&#xff01; View面試專題 View的滑動方式View的事件分發機制View的加載流程…

處理效應模型stata實例_stata︱政策處理效應模型sata基本命令匯總

本文來源經管之家論壇,由壇友cuifengbao歸納 Use ,文件名.dta,clear Ssc installpamatch2,replace 一、首先做一元回歸 reg 結果變量 處理變量,r 二、直接引入協變量,再做多元回歸 reg 結果變量 處理變量 協變量1 協變量2 協變量3……,r 三、接下來進行傾向得分匹配 1.將數…

80后程序員月薪30K+感慨中年危機,面試必問!

說說程序猿行業 現在社會上給IT行業貼上了幾個標簽&#xff1a;高薪、高危、高大上、禿頂&#xff08;哈哈&#xff09;。這些標簽我相比大家都比較清楚&#xff0c;至于為什么是這些標簽呢&#xff1f;而且這些標簽是真實還是假象呢&#xff1f; 高薪 作為IT行業來說&#…

華為照片在哪個文件夾_原來華為手機還能這樣清理垃圾,怪不得你的手機可以多用5年...

對于目前市場上的智能手機來說&#xff0c;大家的手機功能都是差不多的&#xff0c;除了一些外觀上的差別之外&#xff0c;最大的區別就是手機的內存&#xff0c;但是很多朋友卻表示手機內存很大&#xff0c;但是沒用多久&#xff0c;手機就會出現卡頓或者是運行速度變慢的現象…

996頁阿里Android面試真題解析火爆全網,全網首發!

在安卓系統中&#xff1a; 當系統內存不足時&#xff0c;Android系統將根據進程的優先級選擇殺死一 些不太重要的進程&#xff0c;優先級低的先殺死。進程優先級從高到低如下。 前臺進程 處于正在與用戶交互的activity與前臺activity綁定的service調用了startForeground&…

python不適合大型項目_在大型項目上,Python 是個爛語言嗎? |

【洪強寧的回答(89票)】:太多硬傷和臆想&#xff0c;懶得批。只說“代碼超過 10w 以后你就別想用 python 開發了”這一句&#xff0c;2012年4月豆瓣主站項目代碼行數就近50萬行了&#xff0c;可我們還在用 python 開發。【劉鑫的回答(42票)】:我寫過幾年Python&#xff0c;也寫…

996頁阿里Android面試真題解析火爆全網,分享面經!

導語 學歷永遠是橫在我們進人大廠的一道門檻&#xff0c;好像無論怎么努力&#xff0c;總能被那些985,211 按在地上摩擦&#xff01; 不僅要被“他們”看不起&#xff0c;在HR挑選簡歷&#xff0c;學歷這塊就直接被刷下去了&#xff0c;連證明自己的機會也沒有&#xff0c;學…

access ole 對象 最大長度_Redis 數據結構和對象系統,有這 12 張圖就夠了!

作者 | 程序員歷小冰責編 | 林瑟Redis 是一個開源的 key-value 存儲系統&#xff0c;它使用六種底層數據結構構建了包含字符串對象、列表對象、哈希對象、集合對象和有序集合對象的對象系統。 今天我們就通過 12 張圖來全面了解一下它的數據結構和對象系統的實現原理。01數據結…

python煙花表白_python炫酷煙花表白源代碼

詳細內容天天敲代碼的朋友&#xff0c;有沒有想過代碼也可以變得很酷炫又浪漫&#xff1f;今天就教大家用Python模擬出綻放的煙花&#xff0c;工作之余也可以隨時讓程序為自己放一場煙花秀。python炫酷煙花表白源代碼這個有趣的小項目并不復雜&#xff0c;只需一點可視化技巧&a…

【面試總結】2021Java春招面試經歷

三、堆空間 基本描述 JVM啟動時創建堆區&#xff0c;是內存管理的核心區&#xff0c;通常情況下也是最大的內存空間&#xff0c;是被所有線程共享的&#xff0c;幾乎所有的對象實例都要在堆中分配內存&#xff0c;所以這里也是垃圾回收的重點空間。 堆棧關系 棧是JVM運行時的…

tableau地圖城市數據_Tableau 地圖 | 無法識別的城市

Tableau自帶的地圖功能很強大&#xff0c;也很簡單只要雙擊具有地理位置角色的字段&#xff0c;即可生成地圖不過有的時候在你部署地圖的時候總會發現有些城市或地名無法識別&#xff0c;提示如下&#xff1a;這篇post就來簡單聊聊為啥今天直說處理方法&#xff0c;不談后臺原理…

【高級Java架構師系統學習】最新Java高級面試題匯

性能調優 影響MySQLServer 性能的相關因素 商業需求對性能的影響系統架構及實現對性能的影響Query語句對系統性能的影響Schema設計對系統的性能影響硬件環境對系統性能的影響 MySQL 數據庫鎖定機制 MySQL鎖定機制簡介各種鎖定機制分析合理利用鎖機制優化MySQL MySQL數據庫Qu…