旅游城市数量最大化 01背包问题

题目描述

求一个人去旅游能到达的最多的城市。

输入格式

第一行为输入的样例组数T TT。

接着为n nn,m mm(n nn为这个人旅行的总天数,m mm为计划旅行的总城市数)。

接下来一行为一个整数数组d [ i ] d[i]d[i], 每一位依次表示游览每个城市所需的天数。

输出格式

输出一个整数,表示能到达的最多的城市数量。

输入样例

1

5 3

2 1 3

1

2

3

输出样例

2

代码:

#include <iostream>

#include <vector>

#include <map>

#include <algorithm>

#include <cstring>

#include <cmath>

#define MX 100000005

using namespace std;

//背包问题

int t,n,m,d[MX];

int dp[MX];

int main() {

cin>>t;

cin>>n>>m;

for(int i = 1;i <= m;i++)

{

cin>>d[i];

}

dp[0] = 0;

for(int i = 1;i <= m;i++)

{

for(int j = n;j >= d[i];j--)

{

dp[j] = max(dp[j],dp[j-d[i]] + 1);

}

}

cout<<dp[n]<<endl;

return 0;

}

相关推荐
小杨勇敢飞4 分钟前
拼图小游戏开发日记 | Day3(已完结)
java·数据结构·算法
眠りたいです5 分钟前
基于脚手架微服务的视频点播系统-脚手架开发部分-jsoncpp,protobuf,Cpp-httplib与WebSocketpp中间件介绍与使用
c++·websocket·微服务·中间件·json·protobuf·cpp-httplib
Guan jie6 分钟前
10.6作业
数据结构·算法·排序算法
haidizym16 分钟前
ssc-FinLLM 金融大模型 相关链接
人工智能·算法
Macre Aegir Thrym1 小时前
逻辑回归实践
算法·机器学习·逻辑回归
relis1 小时前
llama.cpp RMSNorm CUDA 优化分析报告
算法·llama
chaofa用代码打点酱油1 小时前
RAG 进化之路:传统 RAG 到工具与强化学习双轮驱动的 Agentic RAG
算法·llm
会开花的二叉树1 小时前
C++分布式语音识别服务实践
c++·分布式·语音识别
奔跑吧邓邓子1 小时前
【C++实战(68)】从0到1:C++跨平台开发之Windows API深度实战
c++·windows·实战·跨平台·windows api
nnerddboy2 小时前
QT(c++)开发自学笔记:1.串口
c++·笔记·qt