蓝桥杯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;
}
相关推荐
理智的灰太狼1 小时前
题目 3298: 蓝桥杯2024年第十五届决赛真题-兔子集结
算法·职场和发展·蓝桥杯
鑫鑫向栄9 小时前
[蓝桥杯]缩位求和
数据结构·c++·算法·职场和发展·蓝桥杯
梁下轻语的秋缘9 小时前
每日c/c++题 备战蓝桥杯(P1204 [USACO1.2] 挤牛奶 Milking Cows)
c语言·c++·蓝桥杯
鑫鑫向栄9 小时前
[蓝桥杯]外卖店优先级
数据结构·c++·算法·职场和发展·蓝桥杯
<但凡.9 小时前
题海拾贝:P8598 [蓝桥杯 2013 省 AB] 错误票据
数据结构·算法·蓝桥杯
Swift社区2 天前
AI 的早期萌芽?用 Swift 演绎约翰·康威的「生命游戏」
游戏·蓝桥杯·swift
梁下轻语的秋缘2 天前
每日c/c++题 备战蓝桥杯(P2240 【深基12.例1】部分背包问题)
c语言·c++·蓝桥杯
WenGyyyL3 天前
力扣每日一题——连接两棵树后最大目标节点数目 ||
算法·leetcode·职场和发展·蓝桥杯
a东方青3 天前
[蓝桥杯C++ 2024 国 B ] 立定跳远(二分)
c++·算法·蓝桥杯·c++20
理智的灰太狼3 天前
题目 3293: 蓝桥杯2024年第十五届决赛真题-数位翻转
职场和发展·蓝桥杯