牛客周赛 Round 46:祥子拆团(组合数学,计数问题)

题目描述

Sakiko有两个数字 x,yx,yx,y ,她想知道,有多少种方式可以将 xxx 拆成 yyy 个正整数的乘积。

例如 x=6,y=2x=6,y=2x=6,y=2 时,有 6×1=6,3×2=6,2×3=6,1×6=66 \times 1=6,3 \times 2=6,2 \times 3=6,1 \times 6=66×1=6,3×2=6,2×3=6,1×6=6 这 4 种方法。

由于这个答案可能很大,因此你需要输出答案对 109+710^9 + 7109+7 取模后的结果。

输入描述:

第一行输入一个正整数 T(1≤T≤103)T(1 \leq T \leq 10^3)T(1≤T≤103) ,表示询问次数。接下来 TTT 行,每行输入两个正整数 x,y(1≤x,y≤109)x,y(1 \leq x,y \leq 10^9)x,y(1≤x,y≤109) ,表示询问。

输出描述:

对于每个询问,在一行中输出一个整数表示答案。由于这个答案可能很大,因此你需要输出答案对 109+710^9 + 7109+7 取模后的结果。

示例1

输入

复制2 6 2 12 2

2
6 2
12 2

输出

复制4 6

4
6

说明

第 2 个询问:
[12,1],[6,2],[4,3],[3,4],[2,6],[1,12]
答案为6

代码

#include<bits/stdc++.h>
using namespace std;
int t;
long long x,y;
const long long esp=1e9+7;
long long ksm(long long a,long long b){if(b==0) return 1;long long tmp=a%esp;long long res=1;while(b){if(b%2) res=res*tmp%esp;b/=2;tmp=tmp*tmp%esp;}return res%esp;
}
int main(){scanf("%d",&t);while(t--){scanf("%lld%lld",&x,&y);long long ans=1;for(int i=2;i<=sqrt(x);i++){if(x%i) continue;int d=0;while(x%i==0) x/=i,d++;//求C(y-1,y+d-1),即C(d,y+d-1) 隔板法(保证n>=m)long long res=1;for(int j=y;j<=y+d-1;j++){res=res*j%esp;res=res*ksm(y+d-j,esp-2)%esp;}ans=ans*res%esp;}if(x>1){int d=1;long long res=1;for(int j=y;j<=y+d-1;j++){res*=j%esp;res*=ksm(y+d-j,esp-2)%esp;}ans=ans*res%esp;}cout<<ans<<endl;}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/28434.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

React性能优化分享

本篇将介绍在React编码过程中需要注意的性能优化点。鉴于图片懒加载、虚拟滚动列表等已成为广为人知的通用性能优化手段&#xff0c;本文将不再赘述这些内容。 memo memo允许组件在 props 没有改变的情况下跳过重新渲染 默认通过Object.is比较每个prop&#xff0c;可通过第二个…

可视化大屏开发系列——页面布局

页面布局是可视化大屏的基础&#xff0c;想要拥有一个基本美观的大屏&#xff0c;就得考虑页面整体模块的宽高自适应&#xff0c;我们自然就会想到具有强大灵活性flex布局&#xff0c;再借助百分比布局来辅助。至此&#xff0c;大屏页面布局问题即可得到解决。 写在前面&#x…

哪些数据管理知识领域需要做到数据全生命周期管理

一、数据生命周期 数据管理、数据治理、数据安全、元数据管理、数据治理等知识领域,都需要按照数据的生命周期开展管理工作。数据生命周期包括计划、设计/启用、创建/获取、存储/维护、使用、增强和处置。详见下图。 1.数据治理生命周期 1)规划:将数据要求与业务战略连接起…

PTA 6 - 20 汉诺塔问题(py 递归)

这道题是一道比较典型的递归问题&#xff0c;他跟斐波那契数列的本质是一样的&#xff0c;大家自己动手推理一下&#xff0c;非常好推 参考代码&#xff1a; def hanoi(n,a,b,c):global stepif n 1:print(a,"->",c)step 1else:hanoi(n-1,a,c,b)print(a,"…

查看npm版本异常,更新nvm版本解决问题

首先说说遇见的问题&#xff0c;基本上把nvm&#xff0c;npm的坑都排了一遍 nvm版本导致npm install报错 Unexpected token ‘.‘install和查看node版本都正确&#xff0c;结果查看npm版本时候报错 首先就是降低node版本… 可以说基本没用&#xff0c;如果要降低版本的话&…

用python纯手写一个日历

一、代码 # 月份名称数组 months ["January", "February", "March", "April", "May", "June","July", "August", "September", "October", "November", &qu…

深度解析RocketMq源码-持久化组件(二) MappedFileQueue

1.绪论 MappedFileQueue是commitLog中最核心的主组件。前面讲解commitLog的时候也曾说过&#xff0c;MappedFileQueue本质上就是一个MappedFile队列&#xff0c;而commitLog操纵Mmapped读写的时候&#xff0c;也是通过MappedFileQueue来实现的。 commitlog和mappedfilequeue和…

git下载路径

第一步 1进入官网&#xff1a;Git - Downloading Package 第二步 根据自己的系统选择对应版本下载

局域网内怎么访问另一台电脑?(2种方法)

案例&#xff1a;需要在局域网内远程电脑 “当我使用笔记本电脑时&#xff0c;有时需要获取保存在台式机上的文件&#xff0c;而两者都连接在同一个局域网上。我的台式机使用的是Windows 10企业版&#xff0c;而笔记本电脑则是Windows 10专业版。我想知道是否可以通过网络远程…

springboot-自定义配置

在springboot项目中&#xff0c;最常用的自定义配置就是&#xff0c;在yml文件中&#xff0c;添加一些配置&#xff0c;然后&#xff0c;通过springboot的集成功能&#xff0c;赋值某个bean。 在yml文件中新建我们需要的配置信息&#xff0c;如下&#xff1a; user:id: 2user…

OpenCV计算形状之间的相似度ShapeContextDistanceExtractor类的使用

操作系统&#xff1a;ubuntu22.04OpenCV版本&#xff1a;OpenCV4.9IDE:Visual Studio Code编程语言&#xff1a;C11 1.功能描述 ShapeContextDistanceExtractor是OpenCV库中的一个类&#xff0c;主要用于计算形状之间的相似度或距离。它是基于形状上下文&#xff08;Shape Co…

26.1 WEB框架介绍

1. Web应用程序 1.1 应用程序有两种模式 应用程序的架构模式主要分为两种: C/S (客户端/服务器端)和B/S(浏览器/服务器端). * 1. C/S模式, 即客户端/服务器模式(Client/Server Model): 是一种分布式计算模式.它将应用程序的功能划分为客户端和服务器端两部分.在这种模式下, 客…

码住!详解时序数据库不同分类与性能对比

加速发展中的时序数据库&#xff0c;基于不同架构&#xff0c;最流行的类别是&#xff1f; 作为管理工业场景时序数据的新兴数据库品类&#xff0c;时序数据库凭借着对海量时序数据的高效存储、高可扩展性、时序分析计算等特性&#xff0c;一跃成为物联网时代工业领域颇受欢迎的…

C++升级软件时删除老版本软件的桌面快捷方式(附源码)

删除桌面快捷方式其实是删除桌面上的快捷方式文件,那我们如何去删除桌面快捷方式文件呢?软件可能已经发布过多个版本,其中的一些版本的快捷方式文件名称可能做了多次改动,程序中不可能记录每个版本的快捷方式名称,没法直接去删除快捷方式文件。本文就给出一种有效的处理办…

【GO-OpenCV】go-cv快速配置

最近对golang实现目标检测心血来潮&#xff0c;尝试在没有sudo权限的平台配置go-cv,有所发现&#xff0c;索性多个平台都做尝试 安装Go语言&#xff08;Golang&#xff09; 通过包管理器安装&#xff08;适用于Debian/Ubuntu&#xff09;(有点慢) 更新包列表&#xff1a; sud…

Eclipse 内容辅助

Eclipse 内容辅助 1. 引言 Eclipse 是一款广受欢迎的集成开发环境&#xff08;IDE&#xff09;&#xff0c;它为各种编程语言提供了强大的开发支持。内容辅助&#xff08;Content Assist&#xff09;是 Eclipse 中的一项核心功能&#xff0c;它通过自动提示和代码补全&#x…

Linux命令2

文章目录 移动文件或目录mv格式 查找命令/文件存放位目录置which格式 查找文件或目录find格式查找类型多个查找条件逻辑运算符 移动文件或目录 mv 将文件或者目录移动到指定的位置 如果目标的位置和源位置相同&#xff0c;相当于改名操作 跨目录移动相当于window的剪切 格式…

eNSP学习——帧中继基本配置

目录 主要命令 基本原理 实验目的 实验内容 实验拓扑 实验编址 实验步骤 1、基本配置 2、静态与动态映射的配置 3、子接口配置和静态路由 主要命令 [R1]int s1/0/0 [R1-Serial1/0/0]link-protocol fr //配置链路层协议为FR Warning: The encapsulation protocol…

C++ 算法教程

归并排序 #include<iostream> using namespace std; template <class T> void Merge(T data[],int start,int mid,int end) {int len1 mid - start 1, len2 end - mid;int i, j, k;T* left new int[len1];T* right new int[len2];for (i 0; i < len1; i)…

TF-IDF(Term Frequency-Inverse Document Frequency)

TF-IDF&#xff08;Term Frequency-Inverse Document Frequency&#xff09;是一种常用于信息检索和文本挖掘的统计方法&#xff0c;用以评估一个词语对于一个文件集或一个语料库中的其中一份文件的重要程度。它的重要性随着词语在文本中出现的次数成正比增加&#xff0c;但同时…