牛客网NC276110题解:小红的数组重排

牛客网NC276110题解:小红的数组重排

题目解析

算法思路

  1. 对数组进行排序(非降序)
  2. 检查特殊情况:
    • 如果存在三个连续相等的元素,则无解
    • 如果前两个元素都是0,则无解
  3. 若不存在特殊情况,则排序后的数组即为所求

为什么这样做是正确的?

当我们对数组排序后,相邻元素的乘积往往会递增。但有两种特殊情况需要排除:

  1. 三个连续相等的数:假设有三个连续相等的数x,那么会出现x×x = x×x,不满足严格递增
  2. 开头两个0:如果前两个元素都是0,则a₁×a₂ = 0,而后续任何包含0的乘积也为0,无法形成严格递增序列

代码实现

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
int main()
{
    int n;cin>>n;
    int k[n];
    for(int i=0;i<n;i++){
        cin>>k[i];
    }
    sort(k,k+n);//数组从小到大排列。
    for(int i=0;i<n-2;i++){
        if(k[i]==k[i+1]&&k[i+1]==k[i+2])
        {
            cout<<"NO";
            return 0;
        }
    }
        if(k[0]==k[1]&&k[0]==0)
        {
            cout<<"NO";
            return 0;
        }
    cout<<"YES"<<endl;
    for(int i=0;i<n;i++){cout<<k[i]<<" ";}
    return 0;
}

复杂度分析

  • 时间复杂度:O(nlogn),主要来自排序操作
  • 空间复杂度:O(n),存储输入数组

示例分析

以示例1为例:[7, 2, 5, 1]

  1. 排序后:[1, 2, 5, 7]
  2. 检查特殊情况:
    • 无三个连续相等的数
    • 开头两个数不都是0
  3. 输出排序后的数组:1 2 5 7

验证:1×2 < 2×5 < 5×7,即 2 < 10 < 35 ✓

注意题目示例输出了1 5 2 7,这也是正确答案的一种,因为:1×5 < 5×2 < 2×7,即 5 < 10 < 14 ✓

总结

这道题的关键是发现排序后的数组通常能满足要求,只需排除特殊情况。解题思路简洁明了,实现也很高效。

相关推荐
yumgpkpm4 分钟前
2026软件:白嫖,开源,外包,招标,晚进场(2025年下半年),数科,AI...中国的企业软件产业出路
大数据·人工智能·hadoop·算法·kafka·开源·cloudera
孞㐑¥12 分钟前
算法—队列+宽搜(bfs)+堆
开发语言·c++·经验分享·笔记·算法
yufuu9821 分钟前
并行算法在STL中的应用
开发语言·c++·算法
zh_xuan21 分钟前
单青蛙跳台阶
数据结构·算法
Kx_Triumphs27 分钟前
计算几何-旋转卡壳两种实现方案(兼P1452题解
算法·题解
代码游侠30 分钟前
学习笔记——Linux字符设备驱动开发
linux·arm开发·驱动开发·单片机·嵌入式硬件·学习·算法
m0_736919101 小时前
C++中的享元模式变体
开发语言·c++·算法
罗湖老棍子1 小时前
【 例 1】石子合并(信息学奥赛一本通- P1569)
数据结构·算法·区间dp·区间动态规划·分割合并
wangluoqi2 小时前
26.2.4练习总结
算法
流㶡2 小时前
逻辑回归实战:从原理到不平衡数据优化(含欠拟合/过拟合诊断与召回率提升)
算法·机器学习·逻辑回归