美團-放水果

題目:

放水果
把M個相同的水果放在N個同樣的盤子里,允許有的盤子空著不放,問不同的放法數K是多少?請注意,511151 是同一種放法。輸入描述
第一行是測試數據的數目t(0 <= t <= 20),隨后的每行均包含二個整數M和N,以空格分開。1<=M,N<=10。輸出描述
對輸入的每組數據M和N,在單獨的行里輸出相應的K。樣例輸入
5
2 5
3 3
9 5
2 10
5 1
樣例輸出
2
3
23
2
1

面試官給了提示:

dp[i][j]表示將i個水果放入j個盤子的放法數。我們首先初始化所有dp[i][0]1,因為將任何數量的水果放入0個盤子只有一種方法,即不放。然后,我們逐行填充動態規劃表,對于每個dp[i][j],如果j大于i,則dp[i][j]等于dp[i][i],因為多余的盤子無法放入水果;否則,dp[i][j]等于dp[i][j-1](不使用第j個盤子的放法數)加上dp[i-j][j](使用第j個盤子的放法數)。最后,dp[n][m]就是我們要求的結果。需要考慮兩種情況:一種是不使用第j個盤子,另一種是使用第j個盤子。dp[i][j-1]表示的是第一種情況的放法數,dp[i-j][j]表示的是第二種情況的放法數。將這兩種情況的放法數相加,就得到了總的放法數。

當時是沒看懂的,主要也不太懂為啥dp[i-j][j]表示的是第二種情況的放法數
按照提示寫了代碼,但是運行結果也不對

package mainimport "fmt"
import "io"// To execute Go code, please declare a func main() in a package "main"// The TestCase is shown below
// Input : 1 2
// Output : 3func main() {var t int_,err := fmt.Scanf("%d", &t)if err != nil {fmt.Println("err")return}for i := 0; i < t; i ++ {var M ,N int_,err := fmt.Scanf("%d %d", &M, &N)if err == io.EOF {break}else{// fmt.Println(M, N)fmt.Println(test(M, N))// fmt.Println("Your result is : ", a + b)}}
}func test(M, N int) int {dp := make([][]int, M+1)for i := 0; i <= M; i ++ {dp[i] = make([]int, N+1)dp[i][0] = 1}for i := 0; i <= M; i ++ {for j := 1; j <= N; j ++ {if j > i {dp[i][j] = dp[i][i]} else {dp[i][j] = dp[i-j][j] + dp[i][j-1]}}}return dp[M][N]
}

有大佬路過可以給點幫助

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

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

相關文章

【Spring】19 @Autowired注解使用詳解

文章目錄 構造函數注入Setter方法注入字段注入數組和集合注入特殊情況處理特殊接口類型的注入異常處理結語 Spring 框架的 Autowired 注解是實現依賴注入的一種強大而靈活的方式。在本文中&#xff0c;我們將介紹 Autowired 注解的多種用法&#xff0c;包括構造函數、setter方法…

ICASSP2024 | ICMC-ASR 車載多通道語音識別挑戰賽總結

為促進駕駛場景中語音處理和識別研究&#xff0c;在ISCSLP 2022上成功舉辦智能駕駛座艙語音識別挑戰 (ICSRC)的基礎上&#xff0c;西工大音頻語音與語言處理研究組 (ASLPNPU)聯合理想汽車、希爾貝殼、WeNet社區、字節、微軟、天津大學、南洋理工大學以及中國信息通信研究院等多…

EMO在哪體驗?阿里對口型視頻生成工具EMO下載地址?阿里巴巴新模型EMO的技術原理

這幾天&#xff0c;阿里的對口型視頻生成工具EMO火了。根據官方宣傳&#xff0c;EMO只需要上傳一張圖片和一段音頻就可以一鍵生成對口型視頻&#xff0c;而且視頻中的嘴型還可以與聲音匹配。這項技術支持多語言、對話、唱歌以及快速語速的適配&#xff0c;但也可能成為制造虛假…

pip降級在pycharm中

PyCharm依賴于"–build-dir"參數安裝第三方庫&#xff0c;但該參數在最新的23.0版pip中已刪除 解決辦法就是降級pip&#xff0c;PyCharm中選擇File&#xff0c;找到編譯器&#xff0c;點擊pip&#xff0c;勾選對應版本即可 或者在cmd中執行運行python -m pip install…

基于centos的linux上docker安裝,及mysql、redis等應用在docker容器中的安裝

Docker環境安裝 安裝yum-utils&#xff1a; yum install ‐y yum‐utils device‐mapper‐persistent‐data lvm2為yum源添加docker倉庫位置&#xff1a; yum‐config‐manager ‐‐add‐repo https://download.docker.com/linux/centos/docker‐ce.repo如果上面執行命令后…

【matlab】matlab隨機函數-rand

matlab中rand相關的隨機函數包括rand(),randn(),randi()等。相關用法如下&#xff1a; 1&#xff0c;rand(m,n) 含義&#xff1a;生成0-1間均勻分布的隨機矩陣(m行&#xff0c;n列)&#xff0c;如果mn&#xff0c;則可簡寫為rand(m) >> rand(1) ans 0.8147 ----------…

Linux系統中的高級多線程編程技術

在Linux系統中&#xff0c;多線程編程是一種常見的并發編程模型&#xff0c;通過利用多線程可以實現程序的并發執行&#xff0c;提高系統的性能和響應速度。在Linux系統中&#xff0c;開發人員通常使用 pthread 庫來進行多線程編程&#xff0c;同時需要掌握線程同步技術以避免并…

JVM(4)

垃圾回收問題 垃圾回收算法 通過之前的學習我們可以將死亡對象標記出來了,標記出來后我們就可以進行垃圾回收操作了,在正式學習垃圾處理器之前,我們先來看一下垃圾回收器使用的幾種算法. 標記-清除算法 "標記-清除"算法是基礎的收集算法.算法分為"標記"…

「Vue3系列」Vue3指令

文章目錄 一、Vue3 指令二、注冊-自定義指令三、常見自定義指令1. 聚焦指令&#xff08;v-focus&#xff09;2. 高亮指令&#xff08;v-highlight&#xff09;3. 防抖指令&#xff08;v-debounce&#xff09;4. 限制輸入指令&#xff08;v-limit&#xff09;使用注意事項 四、相…

WPF中如何設置自定義控件

1.圓角按鈕的設置&#xff1a; 眾所周知在WPF中自帶有提示信息&#xff0c;當我問創建Button時&#xff0c;點擊空格出現如下可選設置 帶有小扳手&#x1f527;圖標為相應的屬性&#xff0c;如果Button有CornerRadius&#xff08;角半徑&#xff09;屬性就能夠直接設置Button實…

33. 【Linux教程】Linux 用戶組

前面小節介紹了 Linux 用戶相關的增刪改查&#xff0c;本小節介紹 Linux 用戶組&#xff0c;Linux 系統中采取了一種安全機制&#xff08;即用戶組&#xff09;&#xff0c;用戶組可以允許多個 Linux 用戶共享同一種權限。 1. 用戶組介紹 Linux 是多任務多用戶的操作系統&…

鴻蒙Harmony應用開發—ArkTS聲明式開發(自定義事件分發)

ArkUI在處理觸屏事件時&#xff0c;會在觸屏事件觸發前進行按壓點和組件區域的觸摸測試&#xff0c;來收集需要響應觸屏事件的組件&#xff0c;再基于觸摸測試結果分發相應的觸屏事件。在父節點&#xff0c;開發者可以通過onChildTouchTest決定如何讓子節點去做觸摸測試&#x…

【AI Agent系列】【MetaGPT多智能體學習】5. 多智能體案例拆解 - 基于MetaGPT的智能體辯論(附完整代碼)

本系列文章跟隨《MetaGPT多智能體課程》&#xff08;https://github.com/datawhalechina/hugging-multi-agent&#xff09;&#xff0c;深入理解并實踐多智能體系統的開發。 本文為該課程的第四章&#xff08;多智能體開發&#xff09;的第三篇筆記。主要是對課程剛開始環境搭…

Linux系統——Shell腳本——一鍵安裝LNMP

#!/bin/bash #安裝nginx echo "安裝nginx服務" wget http://nginx.org/download/nginx-1.11.4.tar.gz &>/dev/null if [ $? -eq 0 ] thenecho "nginx-1.11.4安裝包下載完成"echo "--開始安裝必要的依賴文件--"yum install -y gcc gcc-c…

python中map函數

map(str, path)&#xff1a; map函數會將path中的每一個元素傳遞給str函數&#xff0c;從而將它們轉換為字符串。 如果path是一個數字列表&#xff0c;例如[1, 2, 3]&#xff0c;那么map(str, path)將返回[1, 2, 3]。 在寫二叉樹時用到map給樹節點進行str轉換是錯的。 map(s…

xsslabs第五關

看一下源碼 <!DOCTYPE html><!--STATUS OK--><html> <head> <meta http-equiv"content-type" content"text/html;charsetutf-8"> <script> window.alert function() { confirm("完成的不錯&#xff01…

MATLAB知識點:條件判斷 if-elseif-else-end語句

?講解視頻&#xff1a;可以在bilibili搜索《MATLAB教程新手入門篇——數學建模清風主講》。? MATLAB教程新手入門篇&#xff08;數學建模清風主講&#xff0c;適合零基礎同學觀看&#xff09;_嗶哩嗶哩_bilibili 節選自?第4章&#xff1a;MATLAB程序流程控制 if、elseif、…

webstorm 創建運行純Typescript項目

創建一個空項目&#xff0c;在項目根目錄創建一個tsconfig.json文件自動配置&#xff1a; 打開終端輸入tsc --init&#xff0c;即可自動生成tsconfig.json文件手動配置&#xff1a; 在項目根目錄下新建一個tsconfig.json文件,并配置如下內容 具體配置可以直接使用下面的配置&am…

【JavaEE】_Spring MVC項目之建立連接

目錄 1. Spring MVC程序編寫流程 2. 建立連接 2.1 RequestMapping注解介紹 2.2 RequestMapping注解使用 2.2.1 僅修飾方法 2.2.2 修飾類與方法 2.3 關于POST請求與GET請求 2.3.1 GET請求 2.3.2 POST請求 2.3.3 限制請求方法 1. Spring MVC程序編寫流程 1. 建立連接&…

如何開好一家汽車美容店,汽車美容保養與裝飾教學

一、教程描述 本套教程共由17張VCD組合而成&#xff0c;教程內容主要包括&#xff1a;美容店的設立和管理&#xff0c;汽車系統與內部結構&#xff0c;汽車美容工具與美容設備&#xff0c;美容用品的選擇與使用&#xff0c;車身打蠟鍍膜與內外清潔&#xff0c;車身拋光與漆面處…