钥匙计数之二

Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Total Submission(s): 987    Accepted Submission(s): 564

Problem Description
一把钥匙有N个槽,2<N<26槽深为1,2,3,4,5,6。每钥匙至少有3个不同的深度且相连的槽其深度之差不得为5。求这样的钥匙的总数。
 
Input
本题无输入
 
Output
对2<N<26,输出满足要求的钥匙的总数。
 
Sample Output
N=3: 104 N=4: 904 N=5: 5880 . . . . . N=25: 8310566473196300280
 
此题类似于区间DP,有两种思考方式,从前往后和从后往前想,此题从前往后想,int x=0,int y=0;
对于每种分类考虑是否有遗漏和重复 
解法1
假设前n-1个是钥匙,如果加上2,3,4,5是钥匙,那么 x+=4*a[n-1];
如果加上1,6是钥匙的话,那么要除去n-1位是6,1的情况, y+=2*a[i-1]-b[i-1];
假设前n-1个不是钥匙,如果加上2,3,4,5是钥匙,那么x+=4*(C(3,2)+C(3,1)*C(2,1))*((2^(i-1))-2)(由于前n-1个不是钥匙,所以前n-1个只有两种数,不能同时为1和6)
如果加上1,6是钥匙,那么y+=2*(C(4,2)*(2^(i-1)-2)+(C(4,1)*(2^i-2)-1))(从2,3,4,5中选两个,和从2,3,4,5中选一个,对于1选6,对于6选1,两个都放在n-1位置上。)
每一次利用上次处理得到的y(以1或者6结尾的钥匙)更新b[i],b[i]=y;
解法二
定义两种状态,d[i]代表以1和6结尾,dp[i]代表以2 3 4 5结尾
 
#include <stdio.h>
#include <math.h>
#include <cstring>
__int64 a[26],b[26];
void init()
{
   memset(a,0,sizeof(a));
   memset(b,0,sizeof(b));
   a[2]=0;
   a[3]=104;
   b[2]=0;
   b[3]=32;
}
__int64 g(__int64 k ,int b)
{
    __int64 sum=1;
    for(int i=1;i<=b;i++)
     sum*=k;
     return sum;
}
void solve()
{
       for(int i=4;i<=25;i++)
   {
       __int64 x=0,y=0;
       x+=4*a[i-1];
       y+=(2*a[i-1]-b[i-1]);
       x+=4*9*(g(2,i-1)-2);
       y+=2*(6*(g(2,i-1)-2)+4*(g(2,i-2)-1));
       a[i]=x+y;
       b[i]=y;
   }
}
void output()
{
    for(int i=3;i<=25;i++)
        printf("N=%d: %I64d\n",i,a[i]);
}
int main()
{
    //printf("%I64d\n",g(2,25));
 init();
 solve();
 output();
 return 0;
}

hdu 1480的更多相关文章

  1. HDU 5643 King's Game 打表

    King's Game 题目连接: http://acm.hdu.edu.cn/showproblem.php?pid=5643 Description In order to remember hi ...

  2. 转载:hdu 题目分类 (侵删)

    转载:from http://blog.csdn.net/qq_28236309/article/details/47818349 基础题:1000.1001.1004.1005.1008.1012. ...

  3. HDU 2048 神、上帝以及老天爷(错排概率问题)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=2048 神.上帝以及老天爷 Time Limit: 2000/1000 MS (Java/Others) ...

  4. HDU 2050(折线分割平面)

    传送门: http://acm.hdu.edu.cn/showproblem.php?pid=2050 折线分割平面 Time Limit: 2000/1000 MS (Java/Others)    ...

  5. HDOJ 2111. Saving HDU 贪心 结构体排序

    Saving HDU Time Limit: 3000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total ...

  6. 【HDU 3037】Saving Beans Lucas定理模板

    http://acm.hdu.edu.cn/showproblem.php?pid=3037 Lucas定理模板. 现在才写,noip滚粗前兆QAQ #include<cstdio> #i ...

  7. hdu 4859 海岸线 Bestcoder Round 1

    http://acm.hdu.edu.cn/showproblem.php?pid=4859 题目大意: 在一个矩形周围都是海,这个矩形中有陆地,深海和浅海.浅海是可以填成陆地的. 求最多有多少条方格 ...

  8. HDU 4569 Special equations(取模)

    Special equations Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u S ...

  9. HDU 4006The kth great number(K大数 +小顶堆)

    The kth great number Time Limit:1000MS     Memory Limit:65768KB     64bit IO Format:%I64d & %I64 ...

随机推荐

  1. linux rdesktop远程Win7老是提示密码错误问题解决

    最近使用rdesktop远程Win7老是提示密码错误,输了N次,无比确认密码是正确的. 在Win7系统本身登录也是正常的. 但rdesktop远程就是报密码错误. 开始怀疑更新了最新版本问题,但是使用 ...

  2. 从jmm模型漫谈到happens-befor原则

    首先,代码都没有用ide敲,所以不要在意格式,能看懂就行jmm内存模型: jmm是什么? jmm说白了就是定义了jvm中线程和主内存之间的抽象关系的一种模型,也就是线程之间的共享变量存储在主内存,而每 ...

  3. Codevs 2666 2666 Accept Ratio

    时间限制: 1 s  空间限制: 32000 KB   题目等级 : 钻石 Diamond 题目描述 Description 某陈痴迷于pku的ACM题库,常常彻夜奋斗刷题.他最近的目标是在NOIP0 ...

  4. File类 判断功能和获取功能

    package cn.zmh.File; import java.io.File; /* * * File判断功能 * * */ public class FileDemo3判断功能 { public ...

  5. MySQL错误日志、binlog日志、查询日志、慢查询日志简介

    1.数据库的日志是帮助数据库管理员,追踪分析数据库曾经发生的各种事件的有力依据,mysql中提供了错误日志.binlog日志(二进制日志).查处日志.慢查询日志.在此,我力求解决以下问题:各个日志的作 ...

  6. 【C++基础 02】深拷贝和浅拷贝

    我的主题是.每天积累一点点. =========================================== 在类定义中,假设没有提供自己的拷贝构造函数,则C++提供一个默认拷贝构造函数. C ...

  7. 【Nginx】Nginx事件模块

    一.事件处理框架概述 事件处理框架所要解决的问题是如何收集.管理.分发事件.事件以网络事件和定时器事件为主,而网络事件中以TCP网络事件为主.事件处理框架需要在不同的操作系统内核中选择一种事件驱动机制 ...

  8. CentOS 6.x Inotify+Rsync

    CentOS 6.x Inotify+Rsync yum -y install lrzsz [root@rsync ~]# mount -t nfs 10.6.100.75:/volume1/pace ...

  9. [RxJS] Implement the `map` Operator from Scratch in RxJS

    While it's great to use the RxJS built-in operators, it's also important to realize you now have the ...

  10. vue 获取当前时间 格式YYYY-MM-DD

    函数封装: /** * 获取当前时间 * 格式YYYY-MM-DD */ Vue.prototype.getNowFormatDate = function() { var date = new Da ...