题目2693:蓝桥杯2022年第十三届决赛真题-卡牌【排序模拟法图解】

😎卡牌

这道题是最近难得独立想出来的一道题目,从题目到代码没有看过题解, 全是自己的思路

🥰自制动画--过程演示

🤔大致思路

  • 定义每个卡牌为结构体

c 复制代码
struct card {
    int a;
    int b;
};

有两个属性,a表示该卡牌的数量, b表示空卡牌使用次数上限。

  • 根据规律,我们先将所有卡牌按照a的值进行排序:

c 复制代码
sort(cards.begin(), cards.end(), [&](card x, card y)->bool{return x.a < y.a;});

我们用存放card类型的动态数组cards来存放所有的卡牌结构体

  • 根据题目所给定的条件,我们只有m个的空卡牌,也就是我们总共只能对卡牌增加m

所以我们使用一个大循环,次数为m次,每次都只兑换数量最少的卡牌, 也就是a属性最小的卡牌,兑换完后,被兑换的卡牌的可以被增加的机会 就会少一次,那么card.b--。类似于木桶效益,最少的卡牌数量 决定了一套卡牌的数量,所以一旦有一个卡牌次数用完了,直接结束即可。

同时,如果卡牌数量加一后,不再是最小的卡牌,要将这个卡牌放到对应的位置上去,方便下次继续处理最小的卡牌。

⌨️代码

c 复制代码
#include <iostream>
#include <vector>
#include <algorithm>
#define int long long
using namespace std;

struct card {
	int a;
	int b;
};

signed main() {
	ios::sync_with_stdio(false);
	cin.tie(0);
	int n, m;
	cin >> n >> m;
	vector<card> cards(n);
	for (int i = 0; i < n; i++) {
		cin >> cards[i].a;
	}
	for (int i = 0; i < n; i++) {
		cin >> cards[i].b;
	}
	
	sort(cards.begin(), cards.end(), [&](card x, card y) -> bool {
		return x.a < y.a ;
	});
	
	
	while(m--) {
		card &c = cards[0];			//遍历所有的卡片 
		if (c.b > 0) {
			c.a ++, c.b --;
			int i = 0;
			while(cards[i].a > cards[i+1].a) {
				swap(cards[i], cards[i+1]);
				i += 1;
			}
			
		} else {
			break;
		}
	}
	cout << cards[0].a << endl;
	
}
相关推荐
【 】42331 分钟前
C++&STL(Standard Template Library,标准模板库)
java·开发语言·c++
一只牛_00743 分钟前
pthread亲和性继承的一个坑:main绑核让整个进程退化到单核
c++
张健11564096482 小时前
C++访问控制与友元
java·开发语言·c++
BirdenT2 小时前
20260424紫题训练
c++·算法
还是阿落呀2 小时前
基本控制结构
开发语言·c++·算法
样例过了就是过了3 小时前
LeetCode热题100 最长有效括号
c++·算法·leetcode·动态规划
南境十里·墨染春水3 小时前
C++笔记 forward完美转发
开发语言·c++·笔记
吃着火锅x唱着歌3 小时前
深度探索C++对象模型 学习笔记 第四章 Function语意学(2)
c++·笔记·学习
一行代码一行诗++3 小时前
C语言中if的使用
c语言·c++·算法
c++之路3 小时前
C++ STL
java·开发语言·c++