news 2026/3/27 19:14:13

【牛客练习赛 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/24 18:23:57

制造业智能助手:AI驱动的生产决策革新

制造业智能助手&#xff1a;AI驱动的生产决策革新 【免费下载链接】llm-answer-engine Build a Perplexity-Inspired Answer Engine Using Next.js, Groq, Mixtral, Langchain, OpenAI, Brave & Serper 项目地址: https://gitcode.com/GitHub_Trending/ll/llm-answer-eng…

作者头像 李华
网站建设 2026/3/27 5:25:22

3步搞定GPT-2 Large本地部署:从零开始的终极指南

3步搞定GPT-2 Large本地部署&#xff1a;从零开始的终极指南 【免费下载链接】gpt2-large 项目地址: https://ai.gitcode.com/hf_mirrors/openai-community/gpt2-large 还在为API调用费用发愁&#xff1f;担心云端数据隐私问题&#xff1f;本教程将带你用最简单的方式&…

作者头像 李华
网站建设 2026/3/25 8:29:50

如何为ComfyUI添加新的采样算法节点?

如何为ComfyUI添加新的采样算法节点&#xff1f; 在生成式AI的浪潮中&#xff0c;Stable Diffusion 已从研究实验室走向工业级内容生产。然而&#xff0c;传统的 WebUI 虽然易用&#xff0c;却难以满足对流程控制、可复现性和自动化部署的高阶需求。正是在这样的背景下&#xf…

作者头像 李华
网站建设 2026/3/28 2:23:39

【Java毕设源码分享】基于springboot+vue的高校大学生助学贷款系统的设计与实现(程序+文档+代码讲解+一条龙定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/3/25 4:41:27

【Java毕设源码分享】基于springboot+vue的高校超市管理系统设计与实现(程序+文档+代码讲解+一条龙定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华