当前位置: 首页 > news >正文

扬州专业网站制作seo搜索优化工程师招聘

扬州专业网站制作,seo搜索优化工程师招聘,一般网站设计多大宽度,wordpress 简洁文章主题文章目录 隔板法(求解的组数)隔板法扩展 例题 隔板法(求解的组数) 文章首发于我的个人博客:欢迎大佬们来逛逛 隔板法 隔板法能够解决的问题: 求线性不定方程的解的组数求相同元素分组的方案数 给我们 …

文章目录

  • 隔板法(求解的组数)
  • 隔板法
    • 扩展
  • 例题

隔板法(求解的组数)

文章首发于我的个人博客:欢迎大佬们来逛逛

隔板法

隔板法能够解决的问题:

  • 求线性不定方程的解的组数
  • 求相同元素分组的方案数

给我们 n n n 个球, k k k 个盒子,要求把这些球放进这些盒子中,一共有多少种不同的放的方案数

例如:

n = 4 , k = 3 n=4,k=3 n=4k=3 ,方案如下:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-IUTQYuPA-1685533049927)(%E9%9A%94%E6%9D%BF%E6%B3%95%EF%BC%88%E6%B1%82%E8%A7%A3%E7%9A%84%E7%BB%84%E6%95%B0%EF%BC%89%206f4140365b494c00a1407852acf8dd57/Untitled.png)]

容易看出,我们可以划分为 1 1 2 ; 1 2 1; 2 1 1 三种不同的方案。

我们可以把这个问题转换为这样的一个模型:

  • x i > = 1 x_i>=1 xi>=1 的条件下,求 x 1 + x 2 + x 3 + . . . + x k = n x_1+x_2+x_3+...+x_k=n x1+x2+x3+...+xk=n 的方程解的组数

即在这个问题中,方程的解的组数就是:

  1. ( x 1 , x 2 , x 3 ) = ( 1 , 1 , 2 ) (x_1,x_2,x_3)=(1,1,2) (x1,x2,x3)=(1,1,2)
  2. ( x 1 , x 2 , x 3 ) = ( 1 , 2 , 1 ) (x_1,x_2,x_3)=(1,2,1) (x1,x2,x3)=(1,2,1)
  3. ( x 1 , x 2 , x 3 ) = ( 2 , 1 , 1 ) (x_1,x_2,x_3)=(2,1,1) (x1,x2,x3)=(2,1,1)

如何解决这个问题呢?

注意到我们总共有 k = 3 k=3 k=3 个盒子,相当于我们有 k − 1 = 2 k-1=2 k1=2 块板子,然后把这两块板子放到不同的间隔方案数。

对于板子,我们有 k − 1 k-1 k1 块;对于间隔,我们有 n − 1 n-1 n1 个位置。

因此就是求: ∗ ∗ C n − 1 k − 1 **C_{n-1}^{k-1} Cn1k1 的方案数**


扩展

与前面不同,我们需要求在 x i > = 0 x_i>=0 xi>=0 的条件下,求 x 1 + x 2 + x 3 + . . . + x k = n x_1+x_2+x_3+...+x_k=n x1+x2+x3+...+xk=n 的方程解的组数

假设 y i = x i + 1 y_i=x_i+1 yi=xi+1 ,那么 y 1 + y 2 + y 3 + . . . + y k = n + k = m y_1+y_2+y_3+...+y_k=n+k=m y1+y2+y3+...+yk=n+k=m

因此就可以转换为求: C m − 1 k − 1 = C n + k − 1 k − 1 C_{m-1}^{k-1} =C_{n+k-1}^{k-1} Cm1k1=Cn+k1k1方法数


我们需要求在 x i > = a i > = 0 , ∑ 1 n a i < = p x_i>=a_i>=0, \sum_{1}^{n}a_i<=p xi>=ai>=0,1nai<=p 的条件下,求 x 1 + x 2 + x 3 + . . . + x k = n x_1+x_2+x_3+...+x_k=n x1+x2+x3+...+xk=n 的方程解的组数

假设 y i = x i − a i + 1 y_i=x_i-a_i+1 yi=xiai+1,那么 y 1 + y 2 + y 3 + . . . + y k = n − ∑ 1 k a i + k = m y_1+y_2+y_3+...+y_k=n-\sum_{1}^{k}a_i+k=m y1+y2+y3+...+yk=n1kai+k=m

因此就可以转换为求: C m − 1 k − 1 = C n − ∑ i = 1 k a i + k k − 1 C_{m-1}^{k-1}=C_{n-\sum_{i=1}^{k}a_i+k}^{k-1} Cm1k1=Cni=1kai+kk1方案数


例题

方程的解 - 洛谷

  1. 首先求出 x x m o d 1000 x^x mod\space 1000 xxmod 1000 的值,作为 n n n
  2. 然后直接求对应的方案数: C n − 1 k − 1 C_{n-1}^{k-1} Cn1k1
  3. 对于如何处理这个组合数,我们使用求组合数的递推的方法,其中我们需要用到高精度加法来处理。
#include<bits/stdc++.h>
#if 1#define int long long
#endifconst int N=150,p=1000;
int n,k,x;
int dp[1001][101][N+10]; 
int qpow(int a,int b,int p){int ans=1;while (b){if (b&1){ans=ans*a%p;}a=a*a%p;b>>=1;}return ans;
}
void add(int ans[],int A[],int B[]){for (int i=0;i<=N;i++){ans[i]+=A[i]+B[i];ans[i+1]+=ans[i]/10;ans[i]%=10;}
}
void solve(int nn,int mm){//求组合数: C(1000,100)for (int i=0;i<=nn;i++){for (int j=0;j<=i && j<=mm;j++){if (j==0){dp[i][j][0]=1;}else{//高精度加法add(dp[i][j],dp[i-1][j],dp[i-1][j-1]);}}}
}
signed main(){std::cin>>k>>x;n=qpow(x,x,p);//a1+a2+a3...+ak=n//正整数解组数: 满足ai>=1solve(n-1,k-1);int i=N-1;//跳过前导0while (dp[n-1][k-1][i]==0){i--;}while (i>=0){std::cout<<dp[n-1][k-1][i--];}return 0;
}
http://www.yidumall.com/news/61134.html

相关文章:

  • 对外贸易网站有哪些策划推广方案
  • 北京电子商务app网站建设大兴灵感关键词生成器
  • 网站建设 技术支持 阿里广州网络seo优化
  • 成人大专自我鉴定seo排名快速优化
  • 公司做网站好今天的新闻最新消息
  • 网站宣传策略汕头seo外包公司
  • php能开发大型网站无锡谷歌优化
  • 网站网页区别是什么意思百度搜索引擎网址格式
  • wordpress 百度空间优化大师的三大功能
  • 域名注册和网站设计服务南宁百度seo排名公司
  • 网站页面策划开发一个网站的步骤流程
  • node做网站优势职业培训学校加盟合作
  • 呼伦贝尔网站建设呼伦贝尔seo权重优化软件
  • 网站框架怎么设计seo基础教程视频
  • 网站设计职业工作室百度客服人工在线咨询电话
  • 网站建设安全如何优化推广网站
  • 做外贸网站要有域名重庆网络推广专员
  • 申请制作网站各大网站排名
  • 江门做网站seo的十大经典口碑营销案例
  • pc端自适应网站模板优化大师如何删掉多余的学生
  • 电子商务网站建设薛万欣金华seo全网营销
  • 搜索引擎营销的内容和层次有哪些seo指导
  • 新手做自己的网站公司网页制作
  • 网站与网站做外链好吗cms自助建站系统
  • 经常投诉网站快照网站模板库
  • banner在线设计网站今日头条淄博新闻
  • 网站建设的功能定位有没有推广app的平台
  • 深圳网站建设前十名公司网站设计
  • 简历下载免费模板西安网站seo技术厂家
  • wordpress缩略图插件seo国外推广软件