蓝桥杯13届 卡牌

问题描述

这天, 小明在整理他的卡牌。

他一共有 n 种卡牌, 第 i 种卡牌上印有正整数数 i(i∈[1,n]), 且第 i 种卡牌 现有 ai​ 张。

而如果有 n 张卡牌, 其中每种卡牌各一张, 那么这 n 张卡牌可以被称为一 套牌。小明为了凑出尽可能多套牌, 拿出了 m 张空白牌, 他可以在上面写上数 i, 将其当做第 i 种牌来凑出套牌。然而小明觉得手写的牌不太美观, 决定第 i 种牌最多手写 bi​ 张。

请问小明最多能凑出多少套牌?

输入格式

输入共 3 行, 第一行为两个正整数 n,m 。

第二行为 n 个正整数 a1,a2,...,an​ 。

第三行为 n 个正整数 b1,b2,...,bn。

输出格式

一行, 一个整数表示答案。

样例输入

复制代码
4 5
1 2 3 4
5 5 5 5

样例输出

复制代码
3

样例说明

这 5 张空白牌中, 拿 2 张写 1 , 拿 1 张写 2 , 这样每种牌的牌数就变为了 3,3,3,4, 可以凑出 3 套牌, 剩下 2 张空白牌不能再帮助小明凑出一套。

评测用例规模与约定

对于 30% 的数据, 保证 n≤2000;

对于 100% 的数据, 保证 n≤2×; ai,bi≤2n; m≤

从头开始遍历每种纸牌,每遍历一遍 每种纸牌数减1,答案加1

不够减就补,不够补时输出答案

cpp 复制代码
#include<iostream>
using namespace std;

const int N = 2e5+10;
int n;
long long m;

int a[N];
int b[N];
int ans;

int main()
{
	cin>>n>>m;
	for(int i=1; i<=n; ++i) cin>>a[i];
	for(int i=1; i<=n; ++i) cin>>b[i];
	
	int t=1;
	while(t)
	{
		for(int i=1; i<=n; ++i)
		{
			if(a[i]) a[i]--;
			else if(b[i]>0 && m>0)
			{
				b[i]--;
				m--;
			}
			else 
			{
				t = 0;				 
				break;
			}
		}
		
		if(t==0)
		{
			cout<<ans;
			return 0;
		}
		
		ans++;
	}
	
	return 0;
}
相关推荐
christ_lrs8 小时前
sm2025 模拟赛23 (2025.10.18)
贪心·dp·dp优化·基环树·二维数点
红糖生姜1 天前
P12874 [蓝桥杯 2025 国 Python A] 巡逻||题解||图论
c++·蓝桥杯·图论
爱吃生蚝的于勒2 天前
【Linux】零基础学会linux环境基础开发工具使用(yum,vim,makefile,gdb)
linux·服务器·数据结构·c++·蓝桥杯·编辑器·vim
旭意3 天前
C++蓝桥杯之函数与递归
开发语言·c++·蓝桥杯
wuqingshun3141596 天前
蓝桥杯 取球博弈
算法·职场和发展·蓝桥杯
wuqingshun3141597 天前
蓝桥杯 填字母游戏
游戏·职场和发展·蓝桥杯
nju_spy7 天前
力扣每日一题(二)任务安排问题 + 区间变换问题 + 排列组合数学推式子
算法·leetcode·二分查找·贪心·排列组合·容斥原理·最大堆
闻缺陷则喜何志丹9 天前
【C++贪心】P10537 [APIO2024] 九月|普及+
c++·算法·贪心·洛谷
闻缺陷则喜何志丹9 天前
【剪枝 贪心 回溯】B4093 [CSP-X2021 山东] 发送快递|普及+
c++·算法·剪枝·贪心·洛谷
闻缺陷则喜何志丹9 天前
【C++贪心】P8769 [蓝桥杯 2021 国 C] 巧克力|普及+
c++·算法·蓝桥杯·洛谷