蓝桥杯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;
}
相关推荐
yoyobravery6 小时前
蓝桥杯第15届单片机满分
单片机·职场和发展·蓝桥杯
The_era_achievs_hero7 小时前
产品360度展示(蓝桥杯)
蓝桥杯
2301_8090494210 小时前
HAL库速成--嵌入式赛道--蓝桥杯速成
职场和发展·蓝桥杯
打瞌睡的朱尤10 小时前
4.1蓝桥杯训练
职场和发展·蓝桥杯
And_Ii12 小时前
[蓝桥杯 2023 省 A] 更小的数
蓝桥杯
aqiu11111112 小时前
【算法日记 09】蓝桥杯实战:突破整数极限,拥抱“字符串思维”
算法·职场和发展·蓝桥杯
And_Ii12 小时前
[蓝桥杯 2023 省 A] 平方差
蓝桥杯
一轮弯弯的明月2 天前
贝尔数求集合划分方案总数
java·笔记·蓝桥杯·学习心得
迈巴赫车主2 天前
蓝桥杯1458双向排序
java·数据结构·算法·职场和发展·蓝桥杯
liu****2 天前
第16届省赛蓝桥杯大赛C/C++大学B组(京津冀)
开发语言·数据结构·c++·算法·蓝桥杯