HJ131 数独数组

知识点模拟

描述

对于给定的由 nn 个整数组成的数组 {a1,a2,...,an}{a1​,a2​,...,an​},我们称其为数独数组,当且仅当其每一个长度为 99 的连续子数组,都包含 1∼91∼9 这 99 个数字。

现在,对于给定的数组,是否存在一种方案,使得其经过重新排序后成为数独数组?如果是,直接输出 YESYES;否则,输出 NONO。注意,您不必给出具体的排序方案。

输入描述:

第一行输入一个整数 n(9≦n≦105)n(9≦n≦105) 代表数组中的元素数量。

第二行输入 nn 个整数 a1,a2,...,an(1≦ai≦9)a1​,a2​,...,an​(1≦ai​≦9) 代表数组元素。

输出描述:

如果数组在重新排序后可以成为数独数组,输出 YESYES;否则,输出 NONO。

示例1

输入:

复制代码
9
1 2 3 4 5 6 7 9 8

复制输出:

复制代码
YES

复制说明:

复制代码
在这个样例中,不需要经过重新排序,数组已经是一个数独数组。

示例2

输入:

复制代码
9
1 2 3 4 5 6 7 8 1

复制输出:

复制代码
NO
cpp 复制代码
//  #牛客春招刷题训练营# https://www.nowcoder.com/discuss/726480854079250432
#include <algorithm>
#include <array>
#include <iostream>
using namespace std;

int main() {
  ios_base::sync_with_stdio(false);cin.tie(0),cout.tie(0);
  int x, n;
  array<int, 9> a{0};
  cin >> n;
  for (int i = 0; i < n; i++){
    cin >> x;
    a[x - 1]++;//---------计数,计算每个数字出现的次数
  }
  sort(a.begin(), a.end());
  if (a[8] - a[0] > 1)//--------如果出现次数最多的数字的出现次数 - 出现次数最少的数字的出现次数 > 1;就不能实现,否则只需将多出来的部分放在最前面就好了
    cout << "NO";
  else cout << "YES";
}
// 64 位输出请用 printf("%lld")
相关推荐
丷丩14 小时前
三级缓存下MVT地图瓦片服务性能优化策略
算法·缓存·性能优化·gis·geoai-up
m0_6294947314 小时前
LeetCode 热题 100-----25.回文链表
数据结构·算法·leetcode·链表
程序leo源14 小时前
Qt窗口详解
开发语言·数据库·c++·qt·青少年编程·c#
zh_xuan15 小时前
解决VS Code 控制台中文乱码
c++·vscode·乱码
郭涤生15 小时前
飞凌 RK3588 开发板同显 / 异显模式切换
c++·rk3588
计算机安禾15 小时前
【c++面向对象编程】第38篇:设计原则(二):里氏替换、接口隔离与依赖倒置
开发语言·c++
ʚ希希ɞ ྀ15 小时前
单词拆分----dp
算法
code_whiter15 小时前
C++1进阶(继承)
开发语言·c++
智者知已应修善业16 小时前
【51单片机LED闪烁10次数码管显示0-9】2023-12-14
c++·经验分享·笔记·算法·51单片机
智者知已应修善业16 小时前
【51单片机2按键控制1个敞亮LED灯闪烁和熄灭】2023-11-3
c++·经验分享·笔记·算法·51单片机