题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5459

题目描述:给定一个递推得来的字符串,问字符串中不同cff之间的距离之和,

递推规则:

s1=c; s2=ff

sn=s[n-2]s[n-1];

可以观察到任意一个c都被两个ff包含,所以相当于求任意两个c之间的距离之和。

设s[n-2]为p1,p2,p3,,,,p[x],s[n-1]为q1,q2,q3,,,,q[y];

X和y分别为字符串中c的个数;设cnt_c[i]为第i个字符串中c的个数,

all[i]表示第i个字符串的长度,

那么合并之后字符串为p1,p2,p3,,,,p[cnt_c[i-2]],q1+all[i-2],q2+all[i-2],q3+all[i-2]+,,,,q[cnt_c[i-1]]+all[i-2]

设T[i]表示第i个字符串中任意两个c的距离和,

T[i]=T[i-1]+T[i-2]+F[i];

现在讨论F[i],首先考虑q1与之前的组合,

q1+all[i-2]-p1,q1+all[i-2]-p2,q1+all[i-2]-p3,,,q1+all[i-2]-p[cnt_c[i-2]];

合并之后就为:( q1+all[i-2] )*cnt_c[i-2] - (p1+p2+p3,,,+p[cnt_c[i-2]]);

加上q2,q3,,,q[cnt_c[i-1]]之后,答案就为(q1+q2+q3+,,,q[cnt_c[i-1]])*cnt_c[i-2]

+       all[i-2]*cnt_c[i-2] *cnt_c[i-1] -        (p1+p2+p3,,,+p[cnt_c[i-2]])*cnt_c[i-1];

设s[i]表示第i个字符串中不同c之间的距离之和,

T[i]=T[i-2] + T[i-1] +  s[i-1]*cnt_c[i-2]  +   all[i-2]*cnt_c[i-2] *cnt_c[i-1]  - s[i-2]*cnt_c[i-1];

如果答案是负数,第一可能是(a%MOD+MOD)%MOD,第二可能是long  long写成int了

#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <cstring>
#include <iostream>
#define mod 530600414
#define MOD 530600414
#define maxn 201315
#define LL long long
using namespace std;
LL s[maxn],cnt_c[maxn],all[maxn],T[maxn];
//cnt_c代表字符串中有多少个c
//all代表字符串中有多少个字符
//s代表字符串中c位置的和
//T[i]=(cnt_c[i-2]*s[i-1] + cnt_c[i-1] * cnt_c[i-2] *all[i-2] -cnt_c[i-1]*s[i-2]);
void solve()
{
// memset(T,0,sizeof(T));
cnt_c[]=; cnt_c[]=;
all[]=; all[]=;
s[]=; s[]=;
T[]=; T[]=;
for(int i=;i<=;i++)
{
cnt_c[i]=(cnt_c[i-]+cnt_c[i-])%MOD;
all[i]=(all[i-]+all[i-])%MOD;
s[i]=( (s[i-]+s[i-])%MOD + (cnt_c[i-]*all[i-]) %MOD ) %MOD; int a1=( ( ((cnt_c[i-]*all[i-])%MOD - (s[i-] ) ) %MOD *cnt_c[i-])%MOD )%MOD;
int b1=(cnt_c[i-] * s[i-] ) %MOD;
T[i]=((T[i-]+ T[i-]%MOD +MOD)) %MOD;
T[i]=( (T[i]+a1+b1)%MOD +MOD)%MOD;
}
}
int main()
{
// freopen("test.txt","r",stdin);
int t,Case=;
scanf("%d",&t);
solve();
while(t--)
{
int input;
scanf("%d",&input);
printf("Case #%d: %lld\n",++Case,T[input]);
}
return ;
}

最新文章

  1. 去除 UINavigationController.navigationBar下方的横线
  2. Excel 读取字符串引发的问题
  3. HTML 段落&lt;p&gt;标签
  4. python解无忧公主的数学时间编程题001.py
  5. 笔记《Java程序性能优化 让你的Java程序更快、更稳定》 第二章 设计调优
  6. C# 启动进程和杀死进程
  7. uboot的mkconfig分析
  8. [转] shell文本字符串处理
  9. Linux(CentOS6.5) 开放端口,配置防火墙
  10. Tick and Tick------HDOJ杭州电(无法解释,直接看代码)
  11. CPP--借助神器VS理解内存存储
  12. [LeetCode] Reach a Number 达到一个数字
  13. 怎样给手机安装fiddler证书
  14. Windows Server 2012系统上安装.net framework3.5教程
  15. 51NOD 1069 Nim游戏
  16. RabbitMQ 高可用集群搭建
  17. python文本 字符串逐字符反转以及逐单词反转
  18. Code Forces 652D Nested Segments(离散化+树状数组)
  19. uva10288 Coupons 【概率 分数】
  20. 借助Visual Studio Code提高基于ActionScript的LayaAir HTML5游戏的调试效率

热门文章

  1. [codeforces538E]Demiurges Play Again
  2. poj 3683 2-sat问题,输出任意一组可行解
  3. ubuntu使用git时,终端不显示git分支。
  4. 新版VS-code如何自动换行?
  5. Flex4分模块下样式动态加载步骤及相关问题的解决
  6. Meteor软件包管理
  7. mina客户端与服务端通信的易错点
  8. 基于github for windows&amp;amp;github的团队协作基本操作
  9. gvoory脚本中关于HttpClient使用详解实例
  10. MVC 下 JsonResult 的使用方法(JsonRequestBehavior.AllowGet)&lt;转&gt;