news 2026/2/26 1:02:44

《CF961G Partitions》

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
《CF961G Partitions》

题目描述

给定一个包含 n 个元素的集合,元素编号从 1 到 n。第 i 个元素的权值为 wi​。某个子集的权值记为

。将该集合划分为 k 个子集的某个划分 R 的权值为

(回忆一下,集合的划分是指将集合划分为若干个子集,使得每个元素恰好属于一个子集)。

请计算将给定集合划分为恰好 k 个非空子集的所有划分的权值之和,并输出其对 109+7 取模的结果。若存在两个元素 x 和 y,在某个划分中属于同一个子集,在另一个划分中属于不同子集,则这两个划分被认为是不同的。

输入格式

第一行包含两个整数 n 和 k(1≤k≤n≤2⋅105),分别表示元素个数和每个划分中的子集个数。

第二行包含 n 个整数 wi​(1≤wi​≤109),表示集合中每个元素的权值。

输出格式

输出一个整数,表示将集合划分为 k 个非空子集的所有划分的权值之和,对 109+7 取模。

显示翻译

题意翻译

输入输出样例

输入 #1复制

4 2 2 3 2 3

输出 #1复制

160

输入 #2复制

5 2 1 2 3 4 5

输出 #2复制

645

说明/提示

第一个样例的所有可能划分如下:

  1. {{1,2,3},{4}},W(R)=3⋅(w1​+w2​+w3​)+1⋅w4​=24;
  2. {{1,2,4},{3}},W(R)=26;
  3. {{1,3,4},{2}},W(R)=24;
  4. {{1,2},{3,4}},W(R)=2⋅(w1​+w2​)+2⋅(w3​+w4​)=20;
  5. {{1,3},{2,4}},W(R)=20;
  6. {{1,4},{2,3}},W(R)=20;
  7. {{1},{2,3,4}},W(R)=26;

第二个样例的所有可能划分如下:

  1. {{1,2,3,4},{5}},W(R)=45;
  2. {{1,2,3,5},{4}},W(R)=48;
  3. {{1,2,4,5},{3}},W(R)=51;
  4. {{1,3,4,5},{2}},W(R)=54;
  5. {{2,3,4,5},{1}},W(R)=57;
  6. {{1,2,3},{4,5}},W(R)=36;
  7. {{1,2,4},{3,5}},W(R)=37;
  8. {{1,2,5},{3,4}},W(R)=38;
  9. {{1,3,4},{2,5}},W(R)=38;
  10. {{1,3,5},{2,4}},W(R)=39;
  11. {{1,4,5},{2,3}},W(R)=40;
  12. {{2,3,4},{1,5}},W(R)=39;
  13. {{2,3,5},{1,4}},W(R)=40;
  14. {{2,4,5},{1,3}},W(R)=41;
  15. {{3,4,5},{1,2}},W(R)=42。

由 ChatGPT 4.1 翻译

代码实现:

#include<bits/stdc++.h> #define N 200000 #define reg register #define inl inline #define int long long using namespace std; const int md=1e9+7; int n,k,s,a[N+5],f[N+5],iv[N+5]; inl int qp(reg int x,reg int y) { reg int res=1; for(;y;y>>=1,x=x*x%md) if(y&1) res=res*x%md; return res; } inl int calc(reg int x,reg int y) { reg int res=0; for(reg int i=0;i<=y;i++) res=(res+((i&1)?md-1:1)*iv[i]%md*qp(y-i,x)%md*iv[y-i]%md)%md; return res; } signed main() { scanf("%lld %lld",&n,&k); for(reg int i=1;i<=n;i++) { scanf("%lld",&a[i]); s=(s+a[i])%md; } f[0]=1; for(reg int i=1;i<=n;i++) f[i]=f[i-1]*i%md; iv[n]=qp(f[n],md-2); for(reg int i=n-1;i>=0;i--) iv[i]=iv[i+1]*(i+1)%md; reg int ans=s*(calc(n,k)+(n-1)*calc(n-1,k)%md)%md; printf("%lld\n",ans); return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/2/21 16:00:44

用Scikit-learn快速构建机器学习原型:1小时验证你的想法

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个Scikit-learn快速原型工具&#xff0c;支持用户上传数据集后自动进行探索性分析、推荐合适的算法并生成基础模型代码。要求包含一键式数据预处理、多种算法快速测试和结果…

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

5分钟快速原型:用MongoDB构建博客系统

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个极简博客系统原型&#xff0c;要求&#xff1a;1) 使用MongoDB存储文章和评论&#xff1b;2) 实现基本的CRUD功能&#xff1b;3) 支持Markdown格式&#xff1b;4) 包含用户…

作者头像 李华
网站建设 2026/2/24 0:13:07

一键切换:用Llama Factory同时管理多个大模型微调任务

一键切换&#xff1a;用Llama Factory同时管理多个大模型微调任务 作为一名AI实验室的研究员&#xff0c;你是否经常遇到这样的困扰&#xff1a;同时开展多个大模型微调项目时&#xff0c;不同项目间的环境依赖冲突、显存分配混乱、配置文件互相覆盖等问题让人头疼不已&#xf…

作者头像 李华
网站建设 2026/2/25 7:42:55

电商客服语音机器人实战:Sambert-Hifigan一键部署,支持情感切换

电商客服语音机器人实战&#xff1a;Sambert-Hifigan一键部署&#xff0c;支持情感切换 &#x1f4cc; 背景与需求&#xff1a;为什么需要多情感语音合成&#xff1f; 在现代电商客服系统中&#xff0c;自动化语音交互正逐步取代传统机械式播报。然而&#xff0c;冷冰冰的“机器…

作者头像 李华
网站建设 2026/2/18 17:03:30

用Power Query快速验证数据产品创意:1小时原型法

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个数据产品原型生成器&#xff0c;用户输入业务场景描述&#xff08;如分析公众号用户增长趋势&#xff09;&#xff0c;系统自动&#xff1a;1) 生成模拟数据集 2) 配置Pow…

作者头像 李华
网站建设 2026/2/14 6:53:39

CRNN OCR模型缓存优化:提升重复识别速度的技巧

CRNN OCR模型缓存优化&#xff1a;提升重复识别速度的技巧 &#x1f4d6; 项目背景与OCR技术演进 光学字符识别&#xff08;OCR&#xff09;作为连接图像与文本信息的关键技术&#xff0c;广泛应用于文档数字化、票据识别、车牌解析和自然场景文字提取等场景。传统OCR依赖于复杂…

作者头像 李华