统计问题 (空间移动和格子着色)

在一无限大的二维平面中,我们做如下假设:
1、 每次只能移动一格;
2、 不能向后走(假设你的目的地是“向上”,那么你可以向左走,可以向右走,也可以向上走,但是不可以向下走);
3、 走过的格子立即塌陷无法再走第二次;

求走n步不同的方案数(2种走法只要有一步不一样,即被认为是不同的方案)。

这道题的思路需要将向前走和向侧面走分开来讨论,因为前一步是向哪一个方向走的对后一步的方案也有影响作用。
首先,我们假设走n步有f(n)种走法,那么,当在上一步的走法f(n-1)中,有a(n-1)中最后一步是向前的,且b(n-1)种方案最后一步是向侧面的,且有a(n-1)+b(n-1)=f(n-1),f(n)=a(n)+b(n);无论上一步是向前还是侧面,下一步都可以向前,故a(n)=a(n-1)+b(n-1);如果上一步是侧面,那么下一步向侧面只能持续一个方向,如果是向上的,那么下一步要想侧面走的话既可以向左,又可以向右,故b(n)=b(n-1)+2a(n-1).

合并:f(n)=a(n)+b(n)=a(n-1)+b(n-1)+b(n-1)+2a(n-1)=3a(n-1)+2b(n-1)。
到此,可以写出相关代码,即先将a(n),b(n)的值都写出,再根据输入的数值输出答案。

也可以继续变换:f(n)=2f(n-1)+a(n-1)=2f(n-1)+(a(n-2)+b(n-2))=2f(n-1)+f(n-2);

#include <stdio.h>
int a[21]={0,3,7};
void main()
{
    int i,k,n;
    for (i=3;i<=20;i++)
        a[i]=2*a[i-1]+a[i-2];
    scanf("%d",&n);
    while(n--)
    {
        scanf("%d",&k);
        printf("%d\n",a[k]);
    }
}

有排成一行的n个方格,用红(Red)、粉(Pink)、绿(Green)三色涂每个格子,每格涂一色,要求任何相邻的方格不能同色,且首尾两格也不同色.求全部的满足要求的涂法.

这道题的难点在于第n个格子的处理,由于需要满足的是第n个和第一个不同,有两种情况
1、n-1和第1个不同,假设第一个是R,那么第n个应为P或G,那么第n-1个一定也为G或P,第n-2个则一定是R;
2、n-1和第1和相同,那么,第n-2个便有两种与第一个不同的情况,而n也会有两种情况。
在这两种情况下,由于涉及到了n-2项,不妨作出如下推断:
假设第n-2项已经确定,那么,n-2项有三种颜色的可能,分为和1相同和不相同。
1、第n-2项与第一项相同,那么,第n-1项有两种选择(不干涉),第n项有1种选择。总有f(n-1)种。
2、若不同,属于上述的第二种情况,n-1便有一种情况,而第n项有两种情况可选择,为2f(n-2)种。

又因为第n-1项的三种可能都包含在f(n-2)中,所以,f(n)=2f(n-2)+f(n-1);
代码详细如下:

#include <stdio.h>
#include <math.h>
void main()
{
    int n,i;
    __int64 a[51]={0,3,6,6};
    for(i=4;i<=50;i++)
        a[i]=2*a[i-2]+a[i-1];
    while(scanf("%d",&n)!=EOF)
    {
        printf("%I64d\n",a[n]);
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,163评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,301评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,089评论 0 352
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,093评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,110评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,079评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,005评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,840评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,278评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,497评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,667评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,394评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,980评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,628评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,649评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,548评论 2 352

推荐阅读更多精彩内容