球与切换器,51nod1293,思维好题+递推

正题

      通过观察我们会发现,一个1的点从右边出去的必定比从下面出去的多一或者等于,一个-1的点从下面出去的必定比从右边出去的多一或者等于,所以说顺序并不影响一个球到达一个点之后的走向,我们可以根据奇偶判断到达一个点的多个球有多少个球往下走或者往右走。0的情况就很简单了。

      所以就直接f[i][j][0/1]表示第i,j这个点向下走或者向右走的有多少个。

      递推一下,就做完了。

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
using namespace std;

int n,m;
long long k;

long long f[1010][1010][2];//0:down,1:right

int main(){
	scanf("%d %d",&n,&m);
	scanf("%lld",&k);
	f[0][1][0]=k;
	int x;
	for(int i=1;i<=n;i++)
		for(int j=1;j<=m;j++){
			scanf("%d",&x);
			long long res=f[i-1][j][0]+f[i][j-1][1];
			if(x==1) {
				f[i][j][1]=(res+1)/2;
				f[i][j][0]=res/2;
			}
			else if(x==-1){
				f[i][j][1]=res/2;
				f[i][j][0]=(res+1)/2;
			}
			else {
				f[i][j][1]=f[i][j-1][1];
				f[i][j][0]=f[i-1][j][0];
			}
		}
	printf("%lld",f[n][m][0]);
}

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值