好题分享--小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

相关文章

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

java常用面试题-基础知识分享

什么是Java? Java是一种高级编程语言,旨在提供跨平台的解决方案。它是一种面向对象的语言,具有简单、结构化、可移植、可靠、安全等特点。 Java的主要特点是什么? Java的主要特点包括: 简单性:Java的语法相对简单,易于学习和使用。面向对象:Java是一种完全面向对象的语言,支持封装、继承和多态。跨平台性:Java的程序可以在不同的操作系统上运行,称为"Write once,

分享5款免费录屏的工具,搞定网课不怕错过!

虽然现在学生们不怎么上网课, 但是对于上班族或者是没有办法到学校参加课程的人来说,网课还是很重要的,今天,我就来跟大家分享一下我用过的几款录屏软件=,看看它们在录制网课时的表现如何。 福昕录屏大师 网址:https://www.foxitsoftware.cn/REC/ 这款软件给我的第一印象就是界面简洁,操作起来很直观。它支持全屏录制,也支持区域录制,这对于我这种需要同时录制PPT和老师讲

【干货分享】基于SSM的体育场管理系统的开题报告(附源码下载地址)

中秋送好礼 中秋佳节将至,祝福大家中秋快乐,阖家幸福。本期免费分享毕业设计作品:《基于SSM的体育场管理系统》。 基于SSM的体育场管理系统的开题报告 一、课题背景与意义 随着全民健身理念的深入人心,体育场已成为广大师生和社区居民进行体育锻炼的重要场所。然而,传统的体育场管理方式存在诸多问题,如资源分配不均、预约流程繁琐、数据统计不准确等,严重影响了体育场的使用效率和用户体验。

图书管理系统系统分享

分享一个图书管理系统,Java、SpringBoot、Vue和MySQL开发的图书馆管理系统 gitee项目地址:https://gitee.com/yuanmomoya/open-source-project/tree/master/books-management-system GitHub项目地址:https://github.com/yuanmomoya/open-source-pro

站长常用Shell脚本整理分享(全)

站长常用Shell脚本整理分享 站长常用Shell脚本整理分享1-10 站长常用Shell脚本整理分享11-20 站长常用Shell脚本整理分享21-30 站长常用Shell脚本整理分享31-40 站长常用Shell脚本整理分享41-50 站长常用Shell脚本整理分享51-59 长期更新

分享MSSQL、MySql、Oracle的大数据批量导入方法及编程手法细节

1:MSSQL SQL语法篇: BULK INSERT      [ database_name . [ schema_name ] . | schema_name . ] [ table_name | view_name ]         FROM 'data_file'        [ WITH       (      [ [ , ] BATCHSIZE = batch_siz

分享一个基于uniapp科技馆服务微信小程序 博物馆管理小程序(源码、调试、LW、开题、PPT)

💕💕作者:计算机源码社 💕💕个人简介:本人 八年开发经验,擅长Java、Python、PHP、.NET、Node.js、Android、微信小程序、爬虫、大数据、机器学习等,大家有这一块的问题可以一起交流! 💕💕学习资料、程序开发、技术解答、文档报告 💕💕如需要源码,可以扫取文章下方二维码联系咨询 💕💕Java项目 💕💕微信小程序项目 💕💕Android项目 �