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

jsp项目个人网站开发软文免费发布平台

jsp项目个人网站开发,软文免费发布平台,佛山网站制作公司,网站顶部导航文件代码在吗正难则反,考虑长度为 i i i 的排列得到正确的结果的方案数。 设 d p i dp_i dpi​ 表示长度为 i i i 的排列直到循环完也没有提前 return 的方案数。考虑 i i i 所放置的位置,由于不会提前 return,也就说明该数字所在的位置为 [ i − k…

正难则反,考虑长度为 i i i 的排列得到正确的结果的方案数。

d p i dp_i dpi 表示长度为 i i i 的排列直到循环完也没有提前 return 的方案数。考虑 i i i 所放置的位置,由于不会提前 return,也就说明该数字所在的位置为 [ i − k + 1 , i ] [i - k + 1,i] [ik+1,i] 的范围中。因此可以枚举 i i i 的位置为 j j j,则相当于将 [ 1 , i ] [1,i] [1,i] 的区间分为 [ 1 , j − 1 ] , [ j ] , [ j + 1 , i ] [1,j - 1],[j],[j + 1,i] [1,j1],[j],[j+1,i]

第一段为 i − 1 i - 1 i1 个数字中选择 j − 1 j - 1 j1 个,也就是 ( i − 1 j − 1 ) \binom{i-1}{j-1} (j1i1),然后合法的方案数为 d p j − 1 dp_{j - 1} dpj1;第二段放最大值 i i i,第三段还剩下 i − j i - j ij 个数字,随意放置,也就是 ( i − j ) ! (i - j)! (ij)!。虽然说 d p i dp_i dpi 的状态考虑的是排列,但是显然我们只需要考虑数字之间的相对大小,因此第一段的方案数是合理的。可以得到以下转移:

d p i = ∑ j = i − k + 1 i ( i − 1 j − 1 ) × d p j − 1 × ( i − j ) ! dp_i=\sum_{j=i-k+1}^i \binom{i-1}{j-1}\times dp_{j-1}\times (i-j)! dpi=j=ik+1i(j1i1)×dpj1×(ij)!

尝试进行化简,可以得到:

d p i = ∑ j = i − k + 1 i ( i − 1 ) ! ( j − 1 ) ! × ( ( i − 1 ) − ( j − 1 ) ) ! × d p j − 1 × ( i − j ) ! = ∑ j = i − k + 1 i ( i − 1 ) ! ( j − 1 ) ! × d p j − 1 = ( i − 1 ) ! × ∑ j = i − k i − 1 d p j j ! dp_i = \sum_{j=i-k+1}^i \frac{(i - 1)!}{(j - 1)! \times ((i - 1) - (j - 1))!}\times dp_{j-1}\times (i-j)! \\ = \sum_{j=i-k+1}^i\frac{(i - 1)!}{(j - 1)!} \times dp_{j - 1} \\ = (i - 1)! \times \sum_{j=i-k}^{i - 1} \frac{dp_j}{j!} dpi=j=ik+1i(j1)!×((i1)(j1))!(i1)!×dpj1×(ij)!=j=ik+1i(j1)!(i1)!×dpj1=(i1)!×j=iki1j!dpj

维护一段长度为 k k k d p i i ! \frac{dp_i}{i!} i!dpi 的和即可 O ( n ) O(n) O(n) 求出 d p i dp_i dpi

最后再考虑答案。若最后求得的答案是正确的,我们只需要枚举 n n n 所在的位置即可。因此总共合法的方案数为:

a n s = ∑ i = 1 n ( n − 1 i − 1 ) × d p i − 1 × ( n − i ) ! ans = \sum_{i = 1}^n \binom {n - 1}{i - 1} \times dp_{i - 1} \times (n - i)! ans=i=1n(i1n1)×dpi1×(ni)!

最后的答案就是 n ! − a n s n!-ans n!ans。代码如下:

#include <bits/stdc++.h>
#define init(x) memset (x,0,sizeof (x))
#define ll long long
#define ull unsigned long long
#define INF 0x3f3f3f3f
#define pii pair <int,int>
using namespace std;
const int MAX = 1e6 + 5;
const int MOD = 1e9 + 7;
inline int read ();
int n,k;ll tot,sum,dp[MAX],f[MAX],inv[MAX];
ll qpow (ll x,ll y)
{ll res = 1;while (y){if (y & 1) res = res * x % MOD;x = x * x % MOD;y >>= 1;}return res;
}
int main ()
{n = read ();k = read ();inv[0] = f[0] = 1;for (int i = 1;i <= n;++i) f[i] = f[i - 1] * i % MOD;inv[n] = qpow (f[n],MOD - 2);for (int i = n - 1;i;--i) inv[i] = inv[i + 1] * (i + 1) % MOD;dp[0] = sum = 1;for (int i = 1;i <= n;++i){   dp[i] = f[i - 1] * sum % MOD;sum = (sum + dp[i] * inv[i] % MOD) % MOD;if (i >= k) sum = (sum - dp[i - k] * inv[i - k] % MOD + MOD) % MOD;}for (int i = 1;i <= n;++i) tot = (tot + dp[i - 1] * f[n - 1] % MOD * inv[i - 1] % MOD) % MOD;printf ("%lld\n",(f[n] - tot + MOD) % MOD);return 0;
}
inline int read ()
{int s = 0;int f = 1;char ch = getchar ();while ((ch < '0' || ch > '9') && ch != EOF){if (ch == '-') f = -1;ch = getchar ();}while (ch >= '0' && ch <= '9'){s = s * 10 + ch - '0';ch = getchar ();}return s * f;
}
http://www.dtcms.com/wzjs/211586.html

相关文章:

  • 网站建设什么价格怎么做网站卖产品
  • 想弄个网站汕头网站排名优化
  • 商城app开发价格优化大师官方网站
  • 跨境电商网站开发公司市场营销模式有哪些
  • 网站怎么做qq登录界面新东方考研班收费价格表
  • phpstudy做网站运营的坏处谷歌搜索排名规则
  • 临海房产中介网站如何制作西安专业网络推广公司
  • 政府部门网站建设自查报告网上推广怎么做
  • 如何做seo网站才会有排名怎么查看网站的友情链接
  • wordpress 图片被缩小西安seo
  • 个人网站设计界面百度推广一般要多少钱
  • 云浮市住房城乡建设信息网网站营销型网站的类型有哪些
  • 免费婚纱摄影网站模板网站seo站群软件
  • 专业网站设计安徽搜索引擎优化
  • 湖南网站建设企业网络公司主要做哪些
  • 建立网站多少钱一年磁力搜索引擎哪个好
  • 深圳网站建设 乐云seo地推团队接单平台
  • 最适合seo的网站源码网盟推广平台
  • 设一个网站链接为安全怎么做百度推广图片尺寸要求
  • 商业网站是怎么做的seo程序
  • 想要个网站百度运营推广
  • 龙胜网站建设公司国家提供的免费网课平台
  • 深圳网站建设建设百度排名竞价
  • 琼海做球网站山东关键词快速排名
  • wordpress批量提交班级优化大师网页版登录
  • 教育网站设计个人引流推广怎么做
  • 河北网站建设seo优化营销制作设计b站推广网站入口mmm
  • 台州做网站最好的网络推广都需要做什么
  • 利用百度图片做网站外链app推广兼职是诈骗吗
  • 模板网站的优势有哪些广告投放收费标准