news 2026/3/10 1:57:46

【牛客练习赛 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/3/10 0:30:25

低价游陷阱专坑老年人?

「莫道桑榆晚&#xff0c;为霞尚满天」现在有越来越多退休的朋友&#xff0c;不再只是想着在家带带孙子孙女这类事情&#xff0c;而是跟老伙伴约好背上背包&#xff0c;到处去游历大江南北&#xff0c;朋友圈里那些拍摄美景时的笑容&#xff0c;就是老年人重新焕发出生机活力的…

作者头像 李华
网站建设 2026/3/9 20:55:09

Hazel引擎揭秘:如何用开源技术打造高性能2D/3D游戏开发平台

Hazel引擎揭秘&#xff1a;如何用开源技术打造高性能2D/3D游戏开发平台 【免费下载链接】Hazel Hazel Engine 项目地址: https://gitcode.com/gh_mirrors/ha/Hazel 你是否曾梦想开发属于自己的游戏&#xff0c;却被复杂的商业引擎吓退&#xff1f;&#x1f914; Hazel引…

作者头像 李华
网站建设 2026/3/8 17:18:12

Spark-TTS方言合成实战:零样本实现普通话到多地域口音转换

Spark-TTS方言合成实战&#xff1a;零样本实现普通话到多地域口音转换 【免费下载链接】Spark-TTS Spark-TTS Inference Code 项目地址: https://gitcode.com/gh_mirrors/sp/Spark-TTS 你是否曾因标准普通话语音无法让方言使用者理解而困扰&#xff1f;是否在开发地域化…

作者头像 李华
网站建设 2026/3/8 22:53:08

【无标题】激活函数应该具有哪些特征

1.非线性2.可微性3.计算效率高4.缓解梯度消失与爆炸5.合理的输出范围6.稀疏激活能力7.主流激活函数对比&#xff08;扩展版&#xff09;#人工智能#具身智能#VLA#大模型#AI

作者头像 李华