news 2026/4/22 7:34:21

【牛客练习赛 92】B 题题解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【牛客练习赛 92】B 题题解

题目链接

题目大意

给定一个长度为n nn的数组a aa和一个正整数k kk,要求将数组a aa划分为k kk个互不相交的集合,且每个集合的元素和都不为0 00

请构造满足条件的一种划分方案,如若不行输出NO \text{NO}NO

数据范围

Solution

首先可以把所有0 00都放到第1 11个集合里,剩下的数再想办法加入这k kk个集合中的一个。

k = 1 k = 1k=1,只能是∑ i = 1 n a i ≠ 0 \sum\limits_{i = 1}^{n}a_i \neq 0i=1nai=0才能满足条件。

k > 1 k > 1k>1,那么考虑将数组a aa排序(除去0 00之后),若∣ a ∣ < k |a| < ka<k则无解。否则把前k − 1 k - 1k1个数按序加入前k − 1 k - 1k1个集合,最后一个集合加入a aa的末尾元素(即最大数)。

最后对于a k , a k + 1 , ⋯ , a ∣ a ∣ − 1 a_k, a_{k + 1}, \cdots, a_{|a| - 1}ak,ak+1,,aa1,如果是负数,就加入第1 11个集合,否则加入第k kk个集合。

时间复杂度O ( n log ⁡ n ) O(n\log n)O(nlogn)

C++ Code

#include<bits/stdc++.h>usingi64=longlong;intmain(){std::ios::sync_with_stdio(false);std::cin.tie(nullptr);intn,k;std::cin>>n>>k;std::vector<int>a(n);for(auto&x:a){std::cin>>x;}intzer=0;std::vector<int>b;b.reserve(n);for(intx:a){if(x!=0){b.push_back(x);}else{zer++;}}a=std::move(b);std::ranges::sort(a);if(a.size()<k){std::cout<<"NO\n";return0;}std::vector<std::vector<int>>ans(k);ans[0]=std::vector(zer,0);autoprint=[&](){std::cout<<"YES\n";for(constauto&v:ans){std::cout<<v.size()<<" ";for(inti=0;i<v.size();i++){std::cout<<v[i]<<" \n"[i==v.size()-1];}assert(std::reduce(v.begin(),v.end(),0LL)!=0);}};if(k==1){ans[0]=a;if(std::reduce(a.begin(),a.end(),0LL)!=0){print();}else{std::cout<<"NO\n";}return0;}for(inti=0;i<k-1;i++){ans[i].push_back({a[i]});}ans.back().push_back(a.back());for(inti=k-1;i<a.size()-1;i++){if(a[i]<0){ans[0].push_back(a[i]);}else{ans.back().push_back(a[i]);}}print();return0;}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 21:54:45

6、PHP 数组操作、文件处理与流的深入解析

PHP 数组操作、文件处理与流的深入解析 1. 数组操作优化 在 PHP 中,对数组进行操作时,不同的函数使用方式会对内存和性能产生影响。例如,使用 array_map() 函数时,在其执行后会有短暂的时刻存在两个完整的数组。当数组很大时,这种额外的内存分配可能会很显著。 以下代…

作者头像 李华
网站建设 2026/4/21 2:28:41

麒麟服务器操作系统V11安装

本文环境&#xff1a;1.本文是使用VMware17.5.1创建的虚拟机2.远程连接工具是Xshell 8镜像获取麒麟官网虚拟机创建以及部署麒麟v11操作系统自此完成安装使用远程连接工具连接远程连接成功结语上面步骤如果出现问题可以联系我的qq&#xff1a;790073320 我看到了一定会回复大家的…

作者头像 李华
网站建设 2026/4/22 7:33:23

快速上手Replica-Dataset:5步完成3D场景渲染的终极指南

快速上手Replica-Dataset&#xff1a;5步完成3D场景渲染的终极指南 【免费下载链接】Replica-Dataset The Replica Dataset v1 as published in https://arxiv.org/abs/1906.05797 . 项目地址: https://gitcode.com/gh_mirrors/re/Replica-Dataset Replica-Dataset是一个…

作者头像 李华
网站建设 2026/4/22 7:33:24

零门槛AI图像修复神器IOPaint:让每张图片都完美无瑕

零门槛AI图像修复神器IOPaint&#xff1a;让每张图片都完美无瑕 【免费下载链接】IOPaint 项目地址: https://gitcode.com/GitHub_Trending/io/IOPaint 还在为照片中的瑕疵而烦恼&#xff1f;无论是恼人的水印、多余的物体&#xff0c;还是模糊的文字&#xff0c;现在只…

作者头像 李华
网站建设 2026/4/17 23:15:29

量化交易终极指南:开源项目助你快速掌握行业轮动策略

量化交易终极指南&#xff1a;开源项目助你快速掌握行业轮动策略 【免费下载链接】stock 30天掌握量化交易 (持续更新) 项目地址: https://gitcode.com/GitHub_Trending/sto/stock 你是否曾经在股市中追涨杀跌&#xff0c;却总是错过真正的市场热点&#xff1f;面对众多…

作者头像 李华