1371. 貨幣系統-dp背包問題

給定?V種貨幣(單位:元),每種貨幣使用的次數不限。

不同種類的貨幣,面值可能是相同的。

現在,要你用這?V種貨幣湊出?N?元錢,請問共有多少種不同的湊法。

輸入格式

第一行包含兩個整數?V?和?N。

接下來的若干行,將一共輸入?V?個整數,每個整數表示一種貨幣的面值。

輸出格式

輸出一個整數,表示所求總方案數。

數據范圍

1≤V≤25,
1≤N≤10000
答案保證在long long范圍內。

輸入樣例:
3 10
1 2 5
輸出樣例:
10

?

#include <iostream>
#include <cstring>
#include <algorithm>using namespace std;// 定義長整型別名,方便后續使用
typedef long long LL;// 定義常量 N 和 M,分別表示物品數量上限和背包容量上限
const int N = 30, M = 10010;// n 表示物品數量,m 表示背包容量
int n, m;
// v 數組用于存儲每個物品的體積
int v[N];
// f 數組用于存儲狀態,f[i][j] 表示前 i 個物品裝滿容量為 j 的背包的方案數
LL f[N][M];int main()
{// 從標準輸入讀取物品數量 n 和背包容量 mscanf("%d%d", &n, &m);// 循環讀取每個物品的體積for (int i = 1; i <= n; i ++ ) scanf("%d", &v[i]);// 初始化狀態,當沒有物品且背包容量為 0 時,方案數為 1f[0][0] = 1;// 動態規劃過程,枚舉每個物品for (int i = 1; i <= n; i ++ )// 枚舉背包的每個容量for (int j = 0; j <= m; j ++ ){// 不選擇第 i 個物品的方案數f[i][j] = f[i - 1][j];// 如果當前背包容量 j 大于等于第 i 個物品的體積 v[i]if (j >= v[i]) // 選擇第 i 個物品的方案數,累加到 f[i][j] 中f[i][j] += f[i][j - v[i]];}// 輸出前 n 個物品裝滿容量為 m 的背包的方案數printf("%lld\n", f[n][m]);return 0;
}

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

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

相關文章

python和Java的區別

Python和Java是兩種流行的編程語言&#xff0c;它們之間有一些重要的區別&#xff1a; 語法&#xff1a;Python是一種動態類型的腳本語言&#xff0c;語法簡潔明了&#xff0c;通常使用縮進來表示代碼塊。Java是一種靜態類型的編程語言&#xff0c;語法更為嚴格&#xff0c;需要…

正則化是什么?

正則化&#xff08;Regularization&#xff09;是機器學習中用于防止模型過擬合&#xff08;Overfitting&#xff09;的一種技術&#xff0c;通過在模型訓練過程中引入額外的約束或懲罰項&#xff0c;降低模型的復雜度&#xff0c;從而提高其泛化能力&#xff08;即在未見數據上…

計算機網絡——傳輸層(TCP)

傳輸層 在計算機網絡中&#xff0c;傳輸層是將數據向上向下傳輸的一個重要的層面&#xff0c;其中傳輸層中有兩個協議&#xff0c;TCP&#xff0c;UDP 這兩個協議。 TCP 話不多說&#xff0c;我們直接來看協議報頭。 源/目的端口號&#xff1a;表示數據從哪個進程來&#xff0…

界面控件DevExpress WinForms v25.1 - 人工智能(AI)方面全新升級

DevExpress WinForms擁有180組件和UI庫&#xff0c;能為Windows Forms平臺創建具有影響力的業務解決方案。DevExpress WinForms能完美構建流暢、美觀且易于使用的應用程序&#xff0c;無論是Office風格的界面&#xff0c;還是分析處理大批量的業務數據&#xff0c;它都能輕松勝…

WinFrom真入門(1)——Windows窗體應用概念

窗體的基本結構 用Winform開發的桌面程序&#xff0c;是在Windows操作系統上運行的&#xff0c;這個不用多說。窗體&#xff08;Form&#xff09;的作用?&#xff1a;窗體是用戶交互的容器&#xff0c;承載按鈕、文本框等控件&#xff0c;構成應用程序的界面?。 在Windows操…

scss預處理器對比css的優點以及基本的使用

本文主要在vue中演示&#xff0c;scss的基本使用。安裝命令 npm install sass sass-loader --save-dev 變量 SCSS 支持變量&#xff0c;可將常用的值&#xff08;如顏色、字體大小、間距等&#xff09;定義為變量&#xff0c;方便重復使用和統一修改。 <template><…

Postman 如何高效地轉換時間戳?

在 Postman 中&#xff0c;時間戳的處理對于 API 請求和響應的調試和測試至關重要&#xff0c;正確處理時間戳可以確保數據的準確性和一致性&#xff0c;而 Moment 庫和原生 JS 是兩種常見的處理方式。此外&#xff0c;我們還將介紹 Apifox&#xff0c;它提供了更直觀、更簡便的…

iptables學習記錄

一.四表 filter 表&#xff1a; 主要用于控制數據包的過濾&#xff0c;決定數據包是否允許進出及轉發 。比如設置規則允許特定 IP 訪問服務器的 SSH 端口&#xff08;22 端口&#xff09;&#xff0c;或禁止某些 IP 訪問網站端口&#xff08;80 或 443 端口 &#xff09;。可作…

前端自動創建react項目腳手架

步驟&#xff1a;在終端窗口運行如下命令&#xff1a; npm create vitelatest 也可以指定 vite包 版本&#xff0c; 例如&#xff1a; npm create vite4.1.0 npm執行npm install 很慢 還出現證書問題 執行命令行:npm install -g create-vite npm error code UNABLE_TO_GET_IS…

[從零開始學習JAVA ] 了解線程池

前言&#xff1a; 在Java編程中&#xff0c;線程池是一個強大的工具&#xff0c;它能夠管理和復用線程&#xff0c;提供高效的并發處理能力。通過線程池&#xff0c;我們可以有效地控制并發線程的數量&#xff0c;并降低線程創建和銷毀的開銷。本文將引導你深入了解Java中的線程…

Nginx — Nginx處理Web請求機制解析

一、Nginx請求默認頁面資源 1、配置文件詳解 修改端口號為8080并重啟服務&#xff1a; 二、Nginx進程模型 1、nginx常用命令解析 master進程&#xff1a;主進程&#xff08;只有一個&#xff09; worker進程&#xff1a;工作進程&#xff08;可以有多個&#xff0c;默認只有一…

【C++標準IO庫】字符串流

目錄 一、字符串流概述 1.1 流的概念回顧 1.2 字符串流的定義和作用 二、istringstream 的使用 2.1 基本用法 2.2 常見應用場景 三、ostringstream 的使用 3.1 基本用法 3.2 常見應用場景 四、stringstream 的使用 4.1 基本用法 4.2 常見應用場景 五、字符串流的錯…

C語言pthread庫的線程休眠和喚醒的案例

一、代碼如下 #include<stdio.h> #include<pthread.h> // 定義獨占鎖 pthread_mutex_t mutex; // 定義條件信號對象 pthread_cond_t condition; // 初始化函數 void init(){ int code pthread_mutex_init(&mutex, NULL); printf("共享鎖初…

人臉照片比對 API 接口如何對接?

隨著數字化程度加深&#xff0c;身份驗證的重要性也日益凸顯&#xff0c;它成為保障個人信息安全、維護交易秩序的關鍵環節。人臉照片比對 API 接口作為連接人臉比對技術與各類應用的橋梁&#xff0c;正發揮著越來越重要的作用&#xff0c;成為眾多企業和開發者實現高效、安全身…

java學習筆記9——常用類

字符串相關的類&#xff1a; String 指向同一個地址可才相等 注意這個地方&#xff0c;兩個person對象的name實際上指向的是同一個字符串常量池&#xff08;Tom&#xff09; String常用方法 總結&#xff1a; 1.string類的理解(以JDK8為例說明) 1.1 類的聲明 public final cl…

Day 09

文章目錄 指針數組指針和函數技術名詞解釋技術細節課堂筆記 指針數組 #include<stdio.h> int main() {int a[3] {0,1,2};//指針數組&#xff0c;它是數組&#xff0c;每個元素都是指針int *p[3];p[0] &a[0];p[0] a;p[1] &a[1];p[1] a1;p[2] &a[2];p[…

Nginx — Nginx安裝證書模塊(配置HTTPS和TCPS)

一、安裝和編譯證書模塊 [rootmaster nginx]# wget https://nginx.org/download/nginx-1.25.3.tar.gz [rootmaster nginx]# tar -zxvf nginx-1.25.3.tar.gz [rootmaster nginx]# cd nginx-1.25.3 [rootmaster nginx]# ./configure --prefix/usr/local/nginx --with-http_stub_…

計算機網絡 用deepseek幫助整理的復習資料(一)

### 計算機網絡基礎知識整理 --- #### **一、網絡類型** 1. **局域網 (LAN)** - **定義**&#xff1a;覆蓋小范圍&#xff08;如家庭、教室、公司&#xff09;。 - **特點**&#xff1a;高帶寬、低延遲&#xff0c;設備通過交換機互聯。 - **示例**&#xff1…

Linux SCP傳輸文件免密配置

文章目錄 Linux SCP傳輸文件免密配置生成SSH密鑰對將公鑰復制到遠程服務器測試SSH連接使用SCP免密傳輸文件可選配置帶密碼的秘鑰連接處理使用 ssh-agent進行緩存管理&#xff08;該方式只能確保同一個回話中&#xff0c;多次傳輸只輸一次密碼&#xff09;使用 keychain&#xf…

數字電子技術基礎(三十六)——利用Multisim軟件實現3線-8線譯碼器

目錄 1 手動方式實現3線-8線譯碼器 2 使用字選擇器實現3線-8線譯碼器 現在嘗試利用Multisim軟件來實現3線-8線譯碼器。本實驗目的是驗證74LS138的基本功能&#xff0c;簡單來說就是“N中選1”。 實驗設計&#xff1a; &#xff08;1&#xff09;使能信號&#xff1a;時&am…