原题:

pid=688426044611322&round=344496159068801">https://www.facebook.com/hackercup/problems.php?pid=688426044611322&round=344496159068801

题意:你和一个朋友玩足球游戏,分数从0-0開始,终于你总是赢。而且你主要有两种方式赢,第一种stressFree方式你肯定要进第一个球而且总是比你的朋友分数高,另外一种stressFull方式除了你的朋友达到终于分数时。在游戏中你不可能比你的朋友分数高。

给出一个比分。请分别输出在两种情况下你能赢的方式。

题解:相似于LCS。由于球仅仅能一个一个地进,所以给出终于比分,如果a:b,上一个比分仅仅可能是a-1:b,或者a:b-1。

非常easy写出在stressFree时的动态方程。

1. 设dp_free[i][j]为比分为i:j的全部方式数目。显然i > j。

2. 若i = j+1,则dp_free[i][j] = dp_free[i][j-1];若i > j+1,则dp_free[i][j] = dp_free[i][j-1]+dp_free[i-1][j]。

相同如果stressFull方式下的最后比分为a:b,则比分肯定是由b:b再全部由你进球所造成的。

1. 设dp_full[i]为你的分数始终不超过你朋友终于分数为i:j的全部方式数目,显然i <= j。

2. 若i = j,则dp_full[i][j] = dp_full[i-1][j]。若i < j。则dp_full[i][j] = dp_full[i-1][j]+dp_full[i][j-1]。

代码例如以下:

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
#define maxN 2005
#define maxP 1000000007 int dp_free[maxN][maxN];
int dp_full[maxN][maxN]; int DP()
{
memset(dp_free,0,sizeof(dp_free));
memset(dp_full,0,sizeof(dp_full));
dp_free[1][0] = 1;
dp_full[0][0] = 1;
for(int i = 0;i < maxN;i++)
{
for(int j = 0;j < maxN;j++)
{
if(i > j)
{
if(j >= 1)
{
dp_free[i][j] = dp_free[i][j-1];
}
if(i >= 1&&i-1 > j)
{
dp_free[i][j] = (dp_free[i][j]+dp_free[i-1][j])%maxP;
}
}
else
{
if(i >= 1)
{
dp_full[i][j] = dp_full[i-1][j];
}
if(j >= 1&&i <= j-1)
{
dp_full[i][j] = (dp_full[i][j]+dp_full[i][j-1])%maxP;
}
}
}
}
return 0;
} int main()
{
freopen("winning_at_sports.txt","r",stdin);
freopen("out1.txt","w",stdout);
int T;
int a,b;
char c;
DP();
scanf("%d",&T);
for(int i = 1;i <= T;i++)
{
scanf("%d%c%d",&a,&c,&b);
printf("Case #%d: %d %d\n",i,dp_free[a][b],dp_full[b][b]);
}
return 0;
}

Facebook Hacker Cup 2015 Round 1--Winning at Sports(动态规划)的更多相关文章

  1. Facebook Hacker Cup 2015 Round 1--Corporate Gifting(树动态规划)

    原标题:https://www.facebook.com/hackercup/problems.php?pid=759650454070547&round=344496159068801 题意 ...

  2. Facebook Hacker Cup 2015 Round 1--Homework(筛选法求素数)

    题意:给定A,B,K(A<=B)三个数,问在[A,B]范围内的数素数因子个数为K的个数. 题解:典型的筛选法求素数.首先建立一个保存素数因子个数的数组factorNum[],以及到n为止含有素数 ...

  3. Facebook Hacker Cup 2014 Qualification Round 竞赛试题 Square Detector 解题报告

    Facebook Hacker Cup 2014 Qualification Round比赛Square Detector题的解题报告.单击这里打开题目链接(国内访问需要那个,你懂的). 原题如下: ...

  4. 51Nod 1182 完美字符串(字符串处理 贪心 Facebook Hacker Cup选拔)

    1182 完美字符串             题目来源:                         Facebook Hacker Cup选拔         基准时间限制:1 秒 空间限制:1 ...

  5. Codeforces Round VK Cup 2015 - Round 1 (unofficial online mirror, Div. 1 only)E. The Art of Dealing with ATM 暴力出奇迹!

    VK Cup 2015 - Round 1 (unofficial online mirror, Div. 1 only)E. The Art of Dealing with ATM Time Lim ...

  6. Facebook Hacker Cup 2014 Qualification Round

    2014 Qualification Round Solutions 2013年11月25日下午 1:34 ...最简单的一题又有bug...自以为是真是很厉害! 1. Square Detector ...

  7. VK Cup 2015 - Round 2 (unofficial online mirror, Div. 1 only) E. Correcting Mistakes 水题

    E. Correcting Mistakes Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/problemset ...

  8. VK Cup 2015 - Round 1 -E. Rooks and Rectangles 线段树最值+扫描线

    题意: n * m的棋盘, k个位置有"rook"(车),q次询问,问是否询问的方块内是否每一行都有一个车或者每一列都有一个车? 满足一个即可 先考虑第一种情况, 第二种类似,sw ...

  9. VK Cup 2015 - Round 2 (unofficial online mirror, Div. 1 only) B. Work Group 树形dp

    题目链接: http://codeforces.com/problemset/problem/533/B B. Work Group time limit per test2 secondsmemor ...

随机推荐

  1. ios学习之旅---c语言函数

    1.函数的概述 C源程序是由函数组成的. 尽管在前面各章的程序中大都仅仅有一个主函数main(),但有用程序往往由多个 函数组成. 函数是C源程序的基本模块,通过对函数模块的调用实现特定的功能. C语 ...

  2. onblur 对象失去焦点事件

    onblur 对象失去焦点事件 一.总结 1.几乎所有的控件都支持onblur事件 二.简介 onblur 事件 Event 对象 定义和用法 onblur 事件会在对象失去焦点时发生. 语法 onb ...

  3. php数组时按值传递还是按地址传递

    php数组时按值传递还是按地址传递 一.总结 1.数组都是按值:php普通变量和数组的赋值(=)是按值传递,对象的赋值(=)是按址传递 2.对象和按值和按址:对象的clone(用clone关键字)是按 ...

  4. Flume的Agent

    Flume的Agent text(“filename”):将文件filename作为数据源,按行发送 tail(“filename”):探测filename新产生的数据,按行发送出去 fsyslogT ...

  5. golang 函数传值

    package main import ( "fmt" ) type Vertex struct { X, Y int } func dop(a Vertex, vl int) { ...

  6. POJ 2427 Smith's Problem Pell方程

    题目链接 :  http://poj.org/problem?id=2427 PELL方程几个学习的网址: http://mathworld.wolfram.com/PellEquation.html ...

  7. numpy_basic2

    # 六.numpy的常用函数 1. 读取文件 逻辑上可被解释为二维数组的文本文件: 数据项1<分隔符>数据项2<分隔符>...<分隔符>数据项n numpy.loa ...

  8. Appium_Java_API

    1. driver.findElement(MobileBy.AndroidUIAutomator("邀请")).click();2. driver.findElementById ...

  9. c# 调用 C++ dll 传入传出 字符串

    c# 调用 C++ dll 传入传出 字符串 2013-07-02 09:30 7898人阅读 评论(2) 收藏 举报 本文章已收录于:   分类: windows 版权声明:随便转载,随便使用. C ...

  10. Dynamics CRM2016 Web API之Expand related entities &amp; $ref &amp; $count

    本篇介绍两个关于1:N关系中通过主实体取关联子实体的api,这两个api会常常被用到并且比原来的odata方式更加方便.之前假设我们要取主实体下全部的关联实体的记录都是通过Retrieve Multi ...