news 2026/5/1 8:46:42

算法竞赛备考冲刺必刷题(C++) | AcWing 888 求组合数 IV

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
算法竞赛备考冲刺必刷题(C++) | AcWing 888 求组合数 IV

本文分享的必刷题目是从蓝桥云课洛谷AcWing等知名刷题平台精心挑选而来,并结合各平台提供的算法标签和难度等级进行了系统分类。题目涵盖了从基础到进阶的多种算法和数据结构,旨在为不同阶段的编程学习者提供一条清晰、平稳的学习提升路径。

欢迎大家订阅我的专栏:算法题解:C++与Python实现!

附上汇总贴:算法竞赛备考冲刺必刷题(C++) | 汇总


【题目来源】

AcWing:888. 求组合数 IV - AcWing题库

【题目描述】

输入a , b a,ba,b,求C a b C_a^bCab的值。

注意结果可能很大,需要使用高精度计算。

【输入】

共一行,包含两个整数a aab bb

【输出】

共一行,输出C a b C_a^bCab的值。

【输入样例】

5 3

【输出样例】

10

【算法标签】

《AcWing 888 求组合数IV》 #组合数学# #组合计数# #高精度#

【代码详解】

#include<bits/stdc++.h>usingnamespacestd;constintN=5005;// 质数表大小intprimes[N],cnt;// primes存储质数,cnt是质数个数boolst[N];// 筛法标记数组intsum[N];// 存储每个质因子的指数// 线性筛法求1~n的所有质数voidget_primes(intn){for(inti=2;i<=n;i++){if(!st[i])// 如果i是质数{primes[cnt++]=i;// 加入质数表}// 用当前已得到的质数筛掉合数for(intj=0;primes[j]<=n/i;j++){st[primes[j]*i]=true;// 标记合数if(i%primes[j]==0)// 如果primes[j]是i的最小质因数{break;// 保证每个合数只被最小的质因数筛掉}}}}// 计算n!中质因子p的指数(勒让德定理)intget(intn,intp){intres=0;// 指数结果// 勒让德公式:n!中质因子p的指数 = ⌊n/p⌋ + ⌊n/p²⌋ + ⌊n/p³⌋ + ...while(n){res+=n/p;// 计算⌊n/p⌋n/=p;// 继续计算下一项}returnres;}// 高精度乘法:大整数A乘以小整数bvector<int>mul(vector<int>&A,intb){vector<int>C;// 存储结果intt=0;// 进位for(inti=0;i<A.size()||t;i++)// 遍历A的每一位或还有进位{if(i<A.size())// 如果A还有位数{t+=A[i]*b;// 当前位乘以b加上进位}C.push_back(t%10);// 取个位t/=10;// 计算进位}// 去掉前导0,但保留最后一位0(如果结果就是0)while(C.size()>1&&C.back()==0){C.pop_back();}returnC;}intmain(){inta,b;// 输入C(a, b)cin>>a>>b;// 1. 筛出1~a的所有质数get_primes(a);// 2. 计算组合数C(a,b)的质因数分解for(inti=0;i<cnt;i++){intp=primes[i];// 当前质数// 勒让德公式计算C(a,b)中质因子p的指数// C(a,b) = a! / (b! * (a-b)!)// 指数 = 在a!中的指数 - 在b!中的指数 - 在(a-b)!中的指数sum[i]=get(a,p)-get(b,p)-get(a-b,p);}// 3. 用高精度乘法计算结果vector<int>res;// 存储高精度结果,低位在前res.push_back(1);// 初始化为1// 遍历所有质因子for(inti=0;i<cnt;i++){intp=primes[i];// 当前质数intexp=sum[i];// 质因子p的指数// 将p乘exp次for(intj=0;j<exp;j++){res=mul(res,p);}}// 4. 输出结果(从高位到低位)for(inti=res.size()-1;i>=0;i--){cout<<res[i];}cout<<endl;return0;}

【运行结果】

5 3 10
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/25 8:28:48

Java并发编程中的final域介绍

与锁和volatile相比,对final域的读和写更像是普通的变量访问。下面将介绍final域的内存语义。 一、final域的重排序规则 对于final域,编译器和处理器要遵守两个重排序规则。 1)在构造函数内对一个final域的写入,与随后把这个被构造对象的引用赋值给一个引用变量,这两个…

作者头像 李华
网站建设 2026/5/1 7:19:43

java计算机毕业设计校园旧物交易系统 高校二手闲置物品交易平台的设计与实现 基于SpringBoot的校园跳蚤市场系统

计算机毕业设计校园旧物交易系统m198z9&#xff08;配套有源码 程序 mysql数据库 论文&#xff09; 本套源码可以在文本联xi,先看具体系统功能演示视频领取&#xff0c;可分享源码参考。毕业季“搬家季”&#xff0c;成堆的教材、台灯、小风扇从五楼搬到垃圾站&#xff0c;不如…

作者头像 李华
网站建设 2026/5/1 7:22:48

Springboot家政服务管理系统w6nqa(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。

系统程序文件列表项目功能&#xff1a;用户,员工,服务项目,服务类型,服务订单,服务评价开题报告内容一、选题背景与意义1.1 选题背景随着城市化进程加速和生活节奏加快&#xff0c;家政服务需求呈现爆发式增长。据国家统计局数据显示&#xff0c;2024年我国家政服务业市场规模突…

作者头像 李华
网站建设 2026/5/1 4:35:04

含储能及sop的多时段配网优化模型Matlab实现

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。 &#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室 &#x1f34a;个人信条&#xff1a;格物致知,完整Matlab代码获取及仿…

作者头像 李华
网站建设 2026/4/23 5:01:12

简历智能优化平台开发:求职者的AI军师登场

简历智能优化平台开发&#xff1a;求职者的AI军师登场 在当今竞争激烈的就业市场&#xff0c;一份简历的细微差别可能决定面试机会的有无。越来越多求职者开始依赖智能化工具来打磨自己的“职业名片”——但你有没有想过&#xff0c;当你上传简历、点击“优化建议”后&#xff…

作者头像 李华