当前位置: 首页 > news >正文

B-名牌赌王(本人遇到的题,做个笔记)

题解:

#include <iostream>
#include <queue>			//需要用小根堆的优先队列
#include <unordered_map>		//用无序映射
using namespace std;
bool pai()				
{int n, m;cin >> n >> m;		priority_queue<int, vector<int>, greater<int>>q;		//用来往里面存牌unordered_map<int, int>arr;		//记录每张牌的个数while (n--){int num;cin >> num;		//输入当前的牌arr[num]++;		//将当前牌的数量加1q.push(num);		//往优先队列里插入该牌}while (!q.empty())		//根据队列里面个数去循环(只要队列不为空就循环){int number = q.top();		//将队列的堆顶元素(最小值)记录下来q.pop();			//必须得先弹出再去判断这个牌的数量if (arr[number] == 0)	continue;		//如果当前牌的个数为0,则开始下一次循环for (int i = 0; i < m; i++)			//根据每组顺子的长度去循环{int cnt = arr[number+i]--;		//用cnt记录当前牌的个数,记录后,就让当前牌个数-1,因为当前牌构成了顺子,且索引是number+i,因为只有连着的才能构成顺子if (cnt == 0)	return false;			//如果要构成顺子的该牌数量为0,则表示无法构成顺子,返回false}}return true;		//若能顺利构成若干组m长度的顺子,则返回true}
int main()
{int t;cin >> t;while (t--){if (pai())	cout << "YES" << endl;else cout << "NO" << endl;}}

以前写的代码:

#include <bits/stdc++.h>
using namespace std;
int main()
{int t;cin >> t;		//有几副牌vector<int>arr;		//定义的数组来放牌while (t--)		//根据t是多少来循环几次{int n, m;cin >> n >> m;		//输入1副牌的数量以及顺子长度arr.resize(n);for (int i = 0; i < n; i++)	cin >> arr[i];sort(arr.begin(), arr.end(), less<int>());		//将牌从小到大排序int min = 0;	//顺子最开始的那个牌int flag = 0;		//去判断有没有找到顺子的头int count = 0;		//去计算该顺子的目前长度int zushu = 0;		//有几组顺子bool zuizhonflag = 1;		//去判断最终能否符合题中条件,即若干组m长度的顺子if (n % m == 0)		{zushu = n / m;		//来记录顺子有几组}else    //如果不能组成若干组长度为m的顺子则直接终止,看下一副牌{cout << "No" << endl;continue;}while (zushu--)		//有几组顺子就循环几次{zuizhonflag = 1;		//先假设符合题意,能组成若干组长度为m的顺子count = 0;		//将目前顺子长度定义为0flag = 0;		//0表示还没有找到顺子的头for (int i = 0; i < n; i++)		//遍历该副牌{if (arr[i] != 0 && flag == 0)		//若flag=0,且找到第一个不是0的牌,则该牌为顺子的头,用min记录{min = arr[i];arr[i] = 0;		//将该牌删去,记录为0flag = 1;		//1表示找到顺子的头了count++;		//顺子长度加1}if (flag == 1 && arr[i] == min + 1)		//若存在顺子的头,且该牌是顺子中的下一个牌(比如,顺子头是2,则要找3){min = arr[i];		//则将min记录为arr[i](找到3后,把min记录为3,方便去找4)arr[i] = 0;		//将该牌删去count++;		//顺子长度加1}if (count == m)	break;		//若顺子长度到了所规定的m长,则跳出for循环,开始找下一组顺子}if (count != m)			//若遍历完for循环,发现顺子长度不够,则该副牌不符合题意{zuizhonflag = 0;cout << "No" << endl;		//输出No,跳出while循环,开始下一副牌break;}}if (zuizhonflag == 1)			//若该副牌符合题意,则输出YES,并清空vector容器{cout << "Yes" << endl;}arr.clear();		//清空容器}return 0;
}

 参考(来自学长们题解):

 资料:

c++ unordered_map和map的区别-CSDN博客

C++ map与unordered_map区别及使用_c++中的map和unordered_map的区别和使用场景-CSDN博客

相关文章:

B-名牌赌王(本人遇到的题,做个笔记)

题解&#xff1a; #include <iostream> #include <queue> //需要用小根堆的优先队列 #include <unordered_map> //用无序映射 using namespace std; bool pai() {int n, m;cin >> n >> m; priority_queue<int, vector<int>, gr…...

博客评论回复03

接着之前写的&#xff0c;之前返回的数据集按道理来说渲染出来还是丑丑的&#xff0c;因此这次我看着抖音的评论样子&#xff0c;自己瞎写了一通&#xff0c;不过也算是模仿出来了虽然肯定没有抖音写的好。 类似与前面几章写的表结构 首先看看抖音评论区是怎么样的&#xff1f…...

【【萌新的学习之Numpy数组的使用】】

萌新的学习之Numpy数组的使用 先记录一下之前的关于函数的设计 通过创造类的形式 复习完毕之后介绍numpy数组的使用 #整数型数组遇到除法 &#xff08;即便是除以整数&#xff09; 不同维度的数组之间 从外形上的本质区别 一维数组用1层中括号 二维数组用2层中括号 三维数…...

RabbitMQ3.13.x之七_RabbitMQ消息队列模型

RabbitMQ3.13.x之七_RabbitMQ消息队列模型 文章目录 RabbitMQ3.13.x之七_RabbitMQ消息队列模型1. RabbitMQ消息队列模型1. 简单队列2. Work Queues(工作队列)3. Publish/Subscribe(发布/订阅)4. Routing(路由)5. Topics(主题)6. RPC(远程过程调用)7. Publisher Confirms(发布者…...

Android JNI 调用第三方SO

最近一个项目使用了Go 编译了一个so库&#xff0c;但是这个so里面还需要使用第三方so库pdfium, 首先在Android工程把2个so库都放好 在jni中只能使用dlopen方式&#xff0c;其他的使用函数指针的方式来调用&#xff0c;和windows dll类似&#xff0c;不然虽然编译过了但是会崩溃…...

Vid2seq

Vid2Seq 应该是目前为止,个人最中意得一篇能够实际解决对一段视频进行粗略理解得paper了。个人认为它能够真正能解决视频理解是因为它是对一个模型整体做了训练,而不仅仅是通过visual encoders(e.g BLIP/CLIP/…)和 其它multi modal 的encoder直接过了个projection,做一个…...

Opencv人机交互界面设置

Opencv人机交互界面设置 以下是一些常见的OpenCV人机交互界面设置&#xff1a; 窗口交互 显示窗口&#xff1a;可以使用cv2.imshow()函数在屏幕上显示图像。例如&#xff0c;要显示名为“image”的图像&#xff0c;可以使用以下代码&#xff1a; import cv2img cv2.imread…...

蓝桥杯算法心得——字典树考试(贡献度+前缀和)

大家好&#xff0c;我是晴天学长&#xff0c;贡献度的题&#xff0c;找到技巧非常重要&#xff0c;需要的小伙伴可以关注支持一下哦&#xff01;后续会继续更新的。&#x1f4aa;&#x1f4aa;&#x1f4aa; 1) .字典树考试 字典树考试 问题描述 蓝桥学院最近教学了字典树这一数…...

Linux下Qt生成程序崩溃文件

文章目录 1.背景2.Qt编译生成程序2.1.profile模式的本质 3.执行程序&#xff0c;得到core文件4.代码定位4.1.直接使用gdb4.2.使用QtCreator 5.总结6.题外话6.1.profile模式和debug模式的区别 1.背景 在使用Qt时&#xff0c;假如在windows&#xff0c;当软件崩溃时&#xff0c;…...

Go语言中测试和性能

1. 测试:软件开发最重要的方面 测试软件程序可能是软件开发人员能够做的最重要的事情。通过测试代码的功能,开发人员能够在很大程度上确定程序是有效的。另外,每次修改代码后,开发人员都可运行测试,确认没有引入Bug和衰退。通过测试软件,还能够让软件工程师确认程序按期望…...

回归预测 | Matlab基于CPO-GPR基于冠豪猪算法优化高斯过程回归的多输入单输出回归预测

回归预测 | Matlab基于CPO-GPR基于冠豪猪算法优化高斯过程回归的多输入单输出回归预测 目录 回归预测 | Matlab基于CPO-GPR基于冠豪猪算法优化高斯过程回归的多输入单输出回归预测预测效果基本介绍程序设计参考资料 预测效果 基本介绍 Matlab基于CPO-GPR基于冠豪猪算法优化高斯…...

python 日期字符串转换为指定格式的日期

在Python编程中&#xff0c;日期处理是一个常见的任务。我们经常需要将日期字符串转换为Python的日期对象&#xff0c;以便进行日期的计算、比较或其他操作。同时&#xff0c;为了满足不同的需求&#xff0c;我们还需要将日期对象转换为指定格式的日期字符串。本文将详细介绍如…...

day03-Docker

1.初识 Docker 1.1.什么是 Docker 1.1.1.应用部署的环境问题 大型项目组件较多&#xff0c;运行环境也较为复杂&#xff0c;部署时会碰到一些问题&#xff1a; 依赖关系复杂&#xff0c;容易出现兼容性问题开发、测试、生产环境有差异 例如一个项目中&#xff0c;部署时需要依…...

C语言函数实现冒泡排序

前言 今天我们来看看怎么使用函数的方式实现冒泡排序吧&#xff0c;我们以一个数组为例arr[] {9,8,7,6,5,4,3,2,1,0},我们将这个数组通过冒泡排序的方式让他变为升序吧。 代码实现 #include<stdio.h> void bubble_sort(int arr[], int sz) {int i 0;for (i 0;i < s…...

区间概率预测python|QR-CNN-BiLSTM+KDE分位数-卷积-双向长短期记忆神经网络-时间序列区间概率预测+核密度估计

区间预测python|QR-CNN-BiLSTMKDE分位数-卷积-双向长短期记忆神经网络-核密度估计-回归时间序列区间预测 模型输出展示&#xff1a; (图中是只设置了20次迭代的预测结果&#xff0c;宽度较宽&#xff0c;可自行修改迭代参数&#xff0c;获取更窄的预测区间&#xff09; 注&am…...

Java 分支结构 - if…else/switch

顺序结构只能顺序执行&#xff0c;不能进行判断和选择&#xff0c;因此需要分支结构。 Java有两种分支结构&#xff1a; if语句switch语句 if语句 一个if语句包含一个布尔表达式和一条或多条语句。 语法 If 语句的用语法如下&#xff1a; if(布尔表达式) {//如果布尔表达…...

【Unity每日一记】如何从0到1将特效图集制作成一个特效

&#x1f468;‍&#x1f4bb;个人主页&#xff1a;元宇宙-秩沅 &#x1f468;‍&#x1f4bb; hallo 欢迎 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍&#x1f4bb; 本文由 秩沅 原创 &#x1f468;‍&#x1f4bb; 收录于专栏&#xff1a;Uni…...

磁力链接的示例与解释

磁力链接&#xff08;Magnet URI scheme&#xff09;是一种特殊类型的统一资源标识符&#xff08;URI&#xff09;&#xff0c;它包含了通过特定散列函数&#xff08;如SHA-1&#xff09;得到的文件内容的散列值&#xff0c;而不是基于位置或名称的引用。这使得磁力链接成为在分…...

云存储中常用的相同子策略的高效、安全的基于属性的访问控制的论文阅读

参考文献为2022年发表的Efficient and Secure Attribute-Based Access Control With Identical Sub-Policies Frequently Used in Cloud Storage 动机 ABE是实现在云存储中一种很好的访问控制手段,但是其本身的计算开销导致在实际场景中应用收到限制。本论文研究了一种LSSS矩…...

JVM高级篇之GC

文章目录 版权声明垃圾回收器的技术演进ShenandoahShenandoah GC体验Shenandoah GC循环过程 ZGCZGC简介ZGC的版本更迭ZGC体验&使用ZGC的参数设置ZGC的调优 版权声明 本博客的内容基于我个人学习黑马程序员课程的学习笔记整理而成。我特此声明&#xff0c;所有版权属于黑马…...

鸿蒙 HarmonyOS 6 | 网络请求超时重试与弱网适配深度解析

文章目录前言一、网络请求的底层机制与超时配置二、超时重试的核心原理与代码实现三、架构优化策略总结前言 弱网环境下的网络波动极易导致应用与服务端断开连接。这不仅影响软件可用性&#xff0c;更是底层技术架构必须解决的核心问题。鸿蒙 6 在网络请求模块进行了底层架构强…...

企业信息化一站式方案,开启高效管理新时代

企业信息化一站式方案&#xff0c;提升核心竞争力在当今数字化时代&#xff0c;企业面临着日益激烈的市场竞争&#xff0c;如何提升核心竞争力成为企业发展的关键。企业信息化一站式方案应运而生&#xff0c;为企业提供了全面、高效、便捷的解决方案&#xff0c;帮助企业实现数…...

2026知网AIGC检测算法升级,降AI率工具还能有效降论文ai率吗?

2026知网AIGC检测算法升级&#xff0c;降AI率工具还能有效降论文ai率吗&#xff1f; 每到毕业季&#xff0c;关于知网AIGC检测的消息都会在各大高校论坛炸开锅。2026年春季学期刚开始&#xff0c;知网就放出了一个让无数毕业生心头一紧的消息——AIGC检测算法完成了新一轮升级。…...

缺口大!平均月薪超2万元!这个岗位超级火!

当下最火的是什么&#xff1f;答案毫无悬念&#xff0c;一定是人工智能。如今&#xff0c;人工智能行业正以肉眼可见的速度迅速崛起&#xff0c;市场对相关专业人才的需求也随之越来越大。1.市场人才缺口大前几天&#xff0c;人民日报、央视财经等多个主流媒体发布文章&#xf…...

如何快速修复ROG游戏本色彩异常:G-Helper完整配置恢复终极指南

如何快速修复ROG游戏本色彩异常&#xff1a;G-Helper完整配置恢复终极指南 【免费下载链接】g-helper Lightweight Armoury Crate alternative for Asus laptops. Control tool for ROG Zephyrus G14, G15, G16, M16, Flow X13, Flow X16, TUF, Strix, Scar and other models …...

基于CosyVoice与Docker的AI辅助开发实战:从模型部署到生产环境优化

最近在搞一个AI语音合成的项目&#xff0c;用到了CosyVoice这个不错的TTS模型。但在部署环节&#xff0c;真是踩了不少坑&#xff0c;从开发机到测试服务器&#xff0c;再到生产环境&#xff0c;各种Python版本、CUDA版本、依赖库冲突的问题层出不穷&#xff0c;让人头疼。后来…...

想了解西安碑林、雁塔等区二手房装修口碑?这里有你要的答案!

在西安碑林、雁塔等区&#xff0c;二手房装修市场可谓鱼龙混杂&#xff0c;业主们在选择装修公司时常常感到迷茫。毕竟&#xff0c;谁都希望能找到一家靠谱的装修公司&#xff0c;让自己的二手房焕然一新。今天&#xff0c;就给大家重点推荐西安王师傅装修工程有限公司&#xf…...

phpIPAM vs Netbox深度对比:开源IP管理工具选型指南(附GCP云环境部署实录)

phpIPAM vs Netbox深度对比&#xff1a;开源IP管理工具选型指南&#xff08;附GCP云环境部署实录&#xff09; 在数字化转型浪潮中&#xff0c;企业网络基础设施的复杂度呈指数级增长。IP地址作为网络通信的基础要素&#xff0c;其管理效率直接影响运维团队的工作效能。传统Exc…...

OpenClaw硬件推荐:流畅运行nanobot镜像的最低配置与性价比方案

OpenClaw硬件推荐&#xff1a;流畅运行nanobot镜像的最低配置与性价比方案 1. 为什么需要关注硬件配置&#xff1f; 去年夏天&#xff0c;我第一次尝试在笔记本上部署OpenClaw时遭遇了惨痛的失败。那台搭载i5-8250U的轻薄本在启动nanobot镜像后&#xff0c;风扇立刻像直升机一…...

STM32硬件定时器中断库:零HAL依赖多实例调度

1. 项目概述STM32_TimerInterrupt是一个面向 STM32 全系列微控制器&#xff08;覆盖 F0/F1/F2/F3/F4/F7/L0/L1/L4/G0/G4/H7/WB/MP1 等主流型号&#xff09;的轻量级、高可靠硬件定时器中断驱动库。其核心设计目标是在不依赖 HAL 库底层阻塞逻辑的前提下&#xff0c;提供稳定、低…...