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

电商网站开发重难点上海seo推广平台

电商网站开发重难点,上海seo推广平台,河南省今天刚刚人事调整最新,江苏省建设工程招投标网站正难则反,考虑长度为 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/467199.html

相关文章:

  • 罗湖附近公司做网站建设哪家效益快宁波seo深度优化平台有哪些
  • 企业做网站需要多少钱网站的推广优化
  • 开发网站需要什么语言百度搜索引擎收录入口
  • 丽水网站建设企业站长工具seo客户端
  • python网站开发用什么数据库阳东网站seo
  • 网站有信心做的更好平台推广方案模板
  • 网站建设参考网站的说明深圳设计公司
  • wap网站 微信小程序深圳网络推广市场
  • 网站公安局备案流程是骗子网站优化主要优化哪些地方
  • wordpress 说明手册重庆整站seo
  • 如何在网站上做社交的链接全国seo搜索排名优化公司
  • 不用购买域名做网站上海网站建设哪家好
  • 网站页面优化技巧厦门seo大佬
  • 淮安网站建设haclub百度一下 你就知道官方
  • wordpress admin搜索引擎优化的各种方法
  • 富阳网站建设报价长春头条新闻今天
  • 免费使用模板的网站seo的中文名是什么
  • 怎么做外卖网站常德seo
  • wordpress4.x重庆seo薪酬水平
  • 如何看网站是用什么语言做的搜索引擎营销的实现方法有
  • wordpress 置顶标签关键词优化排名工具
  • 如何建设网站app百度免费注册
  • 网站开发项目名seo优化的主要内容
  • 建设社会主义法治国家的参考网站如何免费推广自己的网站
  • 张家港那家做网站百度下载
  • 淘宝网站咋做职业培训网络平台
  • 做英文网站内容来源yandx引擎入口
  • 资料下载网站建设数字营销是干啥的
  • 全国企业工商信息查询官网谷歌seo公司
  • 设计企业网站主页图片深圳网站设计实力乐云seo