好题分享--小A的皇室战争卡组

2024-04-05 22:20

本文主要是介绍好题分享--小A的皇室战争卡组,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述

小 A 很喜欢玩皇室战争这款游戏。皇室战争的卡牌种类共有 3 种,分别为部队、建筑和法术。一个卡组会携带 88 张卡牌,一个合理的卡组会包含 0∼1 张建筑牌、 1∼3 张法术牌,部队牌则没有限制。每张卡牌都有自己独立的等级 ai​ 和种类 ci​。

现在小 A 想和 小 B 进行友谊战,因此需要来构建出战卡组。小 A 共有 n 张卡牌,卡牌的类型与等级已知,且 小 B 的每张出战卡牌的等级已知。由于小 A 对自己的水平非常自信,因此只要 出战卡牌的平均等级 ≥ 对手出战卡牌的平均等级 −2且卡组为一个合理的卡组,则他就能确保取胜。

现在请你帮小 A​ 想想,他可以确保取胜吗?

输入格式

第一行一个整数 T (T≤103) 表示数据组数。

每组第一行输入一个正整数 n (8≤n≤105) ,代表 小A 的卡牌总数,保证 ∑�≤105∑n≤105

每组第二行输入 n 个正整数,代表每张卡牌的种类  ci​ (1≤ci​≤3) ,其中种类 1 代表部队卡,种类 2代表建筑卡,种类 3 代表法术卡。

每组第三行输入 n 个正整数,代表每张卡牌的等级 ai​ (1≤ai​≤15)

每组第四行输入 8 个正整数,代表 小 B 每张卡牌的等级 xi​ (1≤xi​≤15)。

输出格式

共 T 行,每行一个字符串。如果 小A 可以取胜则输出 Yes,否则输出 No

输入输出样例

输入 

3
10
2 3 3 3 1 1 1 1 1 1 
7 8 9 1 2 3 4 5 6 6
13 13 13 13 3 3 3 3
10
2 2 3 1 1 1 1 1 1 1
10 9 2 2 2 2 2 2 2 2
5 5 5 5 5 5 5 6
8
1 1 1 1 1 1 1 1
15 15 15 15 15 15 15 15
1 1 1 1 1 1 1 1

输出 

Yes
No
No

思路:

1.先用结构体数组记录数据,然后按建筑牌,部队牌,法术牌分开排序

2.依题意,建筑牌有两种选择0张或1张,法术牌有三种选择1张、2张或3张,部队牌就用8张减去上面两种选择即可

3.由于我们已经排序过了,所以每次都从下标为0开始取

#include <unordered_map>
#include <cstring> 
using namespace std;
struct node{int x,y;
};int T,n,x;
double average;//记录b的等级 
int bsum;
int a[100010],b[100010],c[100010];
node q[100010];
int p[100010];bool compare(int a,int b){return a>=b;
}int main()
{cin>>T;for(int i=0;i<T;i++){memset(p,0,sizeof p);cin>>n;double maxs=-1e9;for(int j=0;j<n;j++){cin>>q[j].x;p[q[j].x]++;}for(int j=0;j<n;j++) cin>>q[j].y;for(int j=0;j<8;j++) cin>>x,bsum+=x;if(p[3]==0){cout<<"No"<<endl;continue;}for(int j=0;j<n;j++){if(q[j].x==1) a[--p[1]]=q[j].y;else if(q[j].x==2) b[--p[2]]=q[j].y;else if(q[j].x==3) c[--p[3]]=q[j].y;}average=bsum/8-2;sort(a,a+n,compare);sort(b,b+n,compare);sort(c,c+n,compare);for(int j=0;j<=1;j++){for(int k=1;k<=3;k++){int asum=0;for(int o=0;o<8-k-j;o++) asum+=a[o];for(int x=0;x<j;x++) asum+=b[x];for(int y=0;y<k;y++) asum+=c[y];maxs=max(maxs,asum*1.0/8);}}if(maxs>=average) cout<<"Yes"<<endl;else cout<<"No"<<endl;}return 0;
} 

这篇关于好题分享--小A的皇室战争卡组的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/878295

相关文章

linux进程D状态的解决思路分享

《linux进程D状态的解决思路分享》在Linux系统中,进程在内核模式下等待I/O完成时会进入不间断睡眠状态(D状态),这种状态下,进程无法通过普通方式被杀死,本文通过实验模拟了这种状态,并分析了如... 目录1. 问题描述2. 问题分析3. 实验模拟3.1 使用losetup创建一个卷作为pv的磁盘3.

MySQL8.2.0安装教程分享

《MySQL8.2.0安装教程分享》这篇文章详细介绍了如何在Windows系统上安装MySQL数据库软件,包括下载、安装、配置和设置环境变量的步骤... 目录mysql的安装图文1.python访问网址2javascript.点击3.进入Downloads向下滑动4.选择Community Server5.

CentOS系统Maven安装教程分享

《CentOS系统Maven安装教程分享》本文介绍了如何在CentOS系统中安装Maven,并提供了一个简单的实际应用案例,安装Maven需要先安装Java和设置环境变量,Maven可以自动管理项目的... 目录准备工作下载并安装Maven常见问题及解决方法实际应用案例总结Maven是一个流行的项目管理工具

10个Python自动化办公的脚本分享

《10个Python自动化办公的脚本分享》在日常办公中,我们常常会被繁琐、重复的任务占据大量时间,本文为大家分享了10个实用的Python自动化办公案例及源码,希望对大家有所帮助... 目录1. 批量处理 Excel 文件2. 自动发送邮件3. 批量重命名文件4. 数据清洗5. 生成 PPT6. 自动化测试

10个Python Excel自动化脚本分享

《10个PythonExcel自动化脚本分享》在数据处理和分析的过程中,Excel文件是我们日常工作中常见的格式,本文将分享10个实用的Excel自动化脚本,希望可以帮助大家更轻松地掌握这些技能... 目录1. Excel单元格批量填充2. 设置行高与列宽3. 根据条件删除行4. 创建新的Excel工作表5

Redis多种内存淘汰策略及配置技巧分享

《Redis多种内存淘汰策略及配置技巧分享》本文介绍了Redis内存满时的淘汰机制,包括内存淘汰机制的概念,Redis提供的8种淘汰策略(如noeviction、volatile-lru等)及其适用场... 目录前言一、什么是 Redis 的内存淘汰机制?二、Redis 内存淘汰策略1. pythonnoe

Golang操作DuckDB实战案例分享

《Golang操作DuckDB实战案例分享》DuckDB是一个嵌入式SQL数据库引擎,它与众所周知的SQLite非常相似,但它是为olap风格的工作负载设计的,DuckDB支持各种数据类型和SQL特性... 目录DuckDB的主要优点环境准备初始化表和数据查询单行或多行错误处理和事务完整代码最后总结Duck

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

C#读取本地网络配置信息全攻略分享

《C#读取本地网络配置信息全攻略分享》在当今数字化时代,网络已深度融入我们生活与工作的方方面面,对于软件开发而言,掌握本地计算机的网络配置信息显得尤为关键,而在C#编程的世界里,我们又该如何巧妙地读取... 目录一、引言二、C# 读取本地网络配置信息的基础准备2.1 引入关键命名空间2.2 理解核心类与方法

Golang使用etcd构建分布式锁的示例分享

《Golang使用etcd构建分布式锁的示例分享》在本教程中,我们将学习如何使用Go和etcd构建分布式锁系统,分布式锁系统对于管理对分布式系统中共享资源的并发访问至关重要,它有助于维护一致性,防止竞... 目录引言环境准备新建Go项目实现加锁和解锁功能测试分布式锁重构实现失败重试总结引言我们将使用Go作