zoj 1883 - Tight Words

题目:如果一个单词的每个字母都不相差1,我们称为紧密的,给你字母集合{0~k},

问长度为n的单词是紧密的概率。

分析:概率dp。以长度为阶段,结束位置的字符的概率为状态 dp。

状态:设f(i,j)为长度为i的单词,取自集合{ 0,..,k }的紧密概率;

转移:f(i,j)= (f(i-1,j-1)+ f(i,j)+ f(i,j+1))/(k+1);

说明:(2011-11-01 17:40)。

#include <iostream>
#include <cstdlib>
#include <stdio.h>

usingnamespace std;

double F[ 101 ][ 10 ];

int main()
{
    int k,n;
    while ( cin >> k >> n ) {
        double r = 1.0/(1+k);
        for ( int i = 0 ; i <= k ; ++ i )
            F[ 1 ][ i ] = r;
        for ( int i = 2 ; i <= n ; ++ i )
        for ( int j = 0 ; j <= k ; ++ j ) {
            F[ i ][ j ] = F[ i-1 ][ j ]*r;
            if ( j > 0 ) F[ i ][ j ] += F[ i-1 ][ j-1 ]*r;
            if ( j < k ) F[ i ][ j ] += F[ i-1 ][ j+1 ]*r;
        }
        double sum = 0.0;
        for ( int i = 0 ; i <= k ; ++ i )
            sum += F[ n ][ i ];
        printf("%.5lf\n",sum*100);
    }
    return 0;
}
时间: 2024-08-01 08:50:34

zoj 1883 - Tight Words的相关文章

ZOJ(杭电3783)

ZOJ Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Submission(s): 1883    Accepted Submission(s): 1334 Problem Description 读入一个字符串,字符串中包含ZOJ三个字符,个数不一定相等,按ZOJ的顺序输出,当某个字符用完时,剩下的仍然按照ZOJ的顺序输出. Input 题目包含多组用例,每组用

概率dp ZOJ 3640

Help Me Escape Time Limit:2000MS     Memory Limit:32768KB     64bit IO Format:%lld & %llu Submit Status Practice ZOJ 3640 Appoint description:  System Crawler  (2014-10-22) Description Background     If thou doest well, shalt thou not be accepted? an

zoj 2156 - Charlie&#39;s Change

题目:钱数拼凑,面值为1,5,10,25,求组成n面值的最大钱币数. 分析:dp,01背包.需要进行二进制拆分,否则TLE,利用数组记录每种硬币的个数,方便更新. 写了一个 多重背包的 O(NV)反而没有拆分快.囧,最后利用了状态压缩优化 90ms: 把 1 cents 的最后处理,其他都除以5,状态就少了5倍了. 说明:貌似我的比大黄的快.(2011-09-26 12:49). #include <stdio.h> #include <stdlib.h> #include <

ZOJ 1718 POJ 2031 Building a Space Station 修建空间站 最小生成树 Kruskal算法

题目链接:ZOJ 1718 POJ 2031 Building a Space Station 修建空间站 Building a Space Station Time Limit: 2 Seconds      Memory Limit: 65536 KB You are a member of the space station engineering team, and are assigned a task in the construction process of the statio

ZOJ 3607 Lazier Salesgirl (贪心)

Lazier Salesgirl Time Limit: 2 Seconds      Memory Limit: 65536 KB Kochiya Sanae is a lazy girl who makes and sells bread. She is an expert at bread making and selling. She can sell the i-th customer a piece of bread for price pi. But she is so lazy

ZOJ - 2243 - Binary Search Heap Construction

先上题目: Binary Search Heap Construction Time Limit: 5 Seconds      Memory Limit: 32768 KB Read the statement of problem G for the definitions concerning trees. In the following we define the basic terminology of heaps. A heap is a tree whose internal n

ZOJ 2859 二维线段树

思路:自己写的第二发二维线段树1A,哈哈,看来对二维的push操作比较了解了:但是还没遇到在两个线段树中同时进行push操作的,其实这题我是想在x维和y维同时进行push操作的,但是想了好久不会,然后看到这题又给出10秒,然后想想在x维线段直接单点查询肯定也过了,然后在第二维就只有pushup操作,在第一维线段树没有pushup操作.要是在第一维也有pushup操作的话,那就不用单点查询那么慢了.不过也A了,想找题即在二维同时进行pushup和pushdown操作的. #include<iost

ZOJ 2588

求一个无向图的桥(可能存在重边),输出割边的数目,并按顺序输出割边的序号(输入的顺序). 由于内存的限制 , 无法使用邻接矩阵 , 只能用邻接表了 . 第一次用了邻接表,超内存了: 1 #include <iostream> 2 #include <cstdio> 3 #include <algorithm> 4 #include <string.h> 5 using namespace std; 6 const int N=10002; 7 const i

ZOJ 2587 Unique Attack 判断最小割是否唯一

很裸的判断最小割是否唯一.判断方法是先做一遍最大流求最小割,然后从源点和汇点分别遍历所有能够到达的点,看是否覆盖了所有的点,如果覆盖了所有的点,那就是唯一的,否则就是不唯一的. #include <cstdio> #include <cstring> #include <cmath> #include <algorithm> #include <climits> #include <string> #include <iostr