ZOJ 2625 Rearrange Them(DP)
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=1625
题目大意:将n个数重新排列,使得每个数的前一个数都不能和之前的一样,求一共有多少种排列方法
ample Input:
3
4
Sample Output:
3
11
分析:
CrazyAC's 解题报告:
本题一道DP题 仔细想想不难的
首先我们确定状态F[N]表示所产生的新排列的情况数
那么F[N]=f(F[N-1]) 怎么来确定他呢?
由于F[N-1]是排好了;所以只要把N往里插,唯一不可插的地方就是N-1后;所以共有N-1情况,
那么F[N]=(N-1)*F[N-1] (1)似乎这个式子就对了 但是自己手写几组数据是不对的 郁闷中啊~~~
但仔细想想肯定是漏情况了 在哪呢?原来是在我们已经排除的那些组合里,举个例子:N=3
是有3种排列:1 3 2;2 1 3;3 2 1
那么N=4 时,如果只考虑1 3 2;2 1 3;3 2 1这3种就少情况了,原因出在2 3 1;3 1 2这两
个排列没考虑;只要在2 3 1中的2 3之间插4,在3 1 2中的1 2之间插4即可;由此可以发现
在(1)中要加一个参数g(N-1)其表示在N-1个数的排列中,有唯一一对原顺序的排列情况
g(N)如何确定?我们只要用捆绑一对数的思想就可以;举个例子:把1 2 3 4 5 6中的2 3看
成一个数其等价与1 2 3 4 5,所以g(N)=h(F[N-1]),由于捆绑对数就是N-1,就是(1 2 ,2 3, 3 4...)
那么g(N)就确定了:g(N)=(N-1)*F[N-1];所以完成状态方程:F[N]=(N-1)*F[N-1]+(N-2)*F[N-2];
注意边界条件F[0]=0 F[1]=0 F[2]=1 F[3]=3(要用大数)
代码如下:
#include <stdio.h>
#include <string.h> int f[][]; void add(int a,int b,int c){
int i,car=,k;
for(i=;i<=;i++){
k=b*f[b][i]+c*f[c][i]+car;
f[a][i]=k%;
car=k/;
}
} void DP(){
int i;
memset(f,,sizeof(f));
f[][]=;
f[][]=;
f[][]=;
f[][]=;
for(i=;i<=;i++){
add(i,i-,i-);
}
} int main()
{
int i,j,n;
DP();
while(scanf("%d",&n)!=EOF){
if(n== || n==){
printf("0\n");
continue;
}
for(i=;i>=;i--)
if(f[n][i]) break;
for(j=i;j>=;j--)
printf("%d",f[n][j]);
printf("\n");
}
return ;
}
ZOJ 2625 Rearrange Them(DP)的更多相关文章
- ZOJ 4027 Sequence Swapping(DP)题解
题意:一串括号,每个括号代表一个值,当有相邻括号组成()时,可以交换他们两个并得到他们值的乘积,问你最大能得到多少 思路:DP题,注定想得掉头发. 显然一个左括号( 的最远交换距离由他右边的左括号的最 ...
- ZOJ 2745 01-K Code(DP)(转)
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=1745 题目大意:一个串由N个字符组成,每个字符是‘0’或者是‘1’, ...
- ZOJ 1013 Great Equipment(DP)
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=13 题目大意:说的是有三种不同的装备,分别是头盔,盔甲,战靴需要运输, ...
- ZOJ 3211 Dream City(DP)
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=3374 题目大意:JAVAMAN 到梦幻城市旅游见到了黄金树,黄金树上 ...
- ZOJ 2702 Unrhymable Rhymes(DP)
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemId=1702 题目大意:给定有很多数字组成的诗,譬如 “AABB”, “AB ...
- LightOJ 1033 Generating Palindromes(dp)
LightOJ 1033 Generating Palindromes(dp) 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid= ...
- lightOJ 1047 Neighbor House (DP)
lightOJ 1047 Neighbor House (DP) 题目链接:http://acm.hust.edu.cn/vjudge/contest/view.action?cid=87730# ...
- UVA11125 - Arrange Some Marbles(dp)
UVA11125 - Arrange Some Marbles(dp) option=com_onlinejudge&Itemid=8&category=24&page=sho ...
- ZOJ 2477 Magic Cube(魔方)
ZOJ 2477 Magic Cube(魔方) Time Limit: 2 Seconds Memory Limit: 65536 KB This is a very popular gam ...
随机推荐
- Windows 环境下基于 nginx 的本地 PyPI 源
Windows 环境下基于 nginx 的本地 PyPI 源的搭建: 1.登录 nginx 官网,下载安装包
- 【转】解决HttpServletResponse输出的中文乱码问题
http://blog.csdn.net/simon_1/article/details/9092747 首先,response返回有两种,一种是字节流outputstream,一种是字符流print ...
- 【转】/etc/grub.conf文件详解
转自:http://leejia.blog.51cto.com/4356849/788902 grub.conf是grub的主配置文件,通过这个配置文件,grub才能找到kernel,系统才能正常启动 ...
- careercup-中等难度 17.4
17.4 编写一个方法,找出两个数字中最大的那一个.不得使用if-else或其他比较运算符. 解法: 我们可以通过一步步的分析来将需要用到的if-else和比较操作符去掉: If a > b, ...
- webService 讲解
Web Service简介: Web Service 是构建互联网分布式系统的基本部件,可以将具有特定功能或者可复用应用程序封装. 技术组成要素: SOAP:Web Service的基本通信协议,由普 ...
- java_spring_依赖注入(构造器)
依赖注入对象可以 手工装配(建议) 和 自动装配 package com.PersonDaoBean.test; public interface PersonDao { public abstrac ...
- java_spring_bean的作用域_实例是否为单实例
<?xml version="1.0" encoding="UTF-8"?> <beans xmlns="http://www.sp ...
- 如何在mac上創建txt文档
文件編輯(Mac下的記事本),shift + command + T 進入純文字編輯模式!
- Android 框架修炼-自己封装双缓存管理框架库
一.概述 Android开发中,网络请求是很重要的一部分,而缓存网络请求来的图片或者响应结果字符串或者结果流,既可以省流量,同时也可以帮助我们 解决无网或弱网情况下加载情况,当然也可以提升程序性能效率 ...
- Android-Opencv开发(一)配置环境
先去官网下载android-opencv http://opencv.org/.