洛谷练习(8.6)

P1002 过河卒

题目描述

棋盘中有一个马士兵不能经过马,也不能经过马走一步就能到的位置,计算到终点有几种可能

思路

士兵只能往右或者下走,所以最后一个位置只能从上或者左过去;可能性就dp[i][j]=d[i-1][j]+d[i][-1],依次类推

代码

void solve()
{
	int a,b,c,d;//记得把int定义为long long,或者直接用long long 定义
    int dp[30][30];//记录路数
    int q[30][30]={0};//记录不能走的位置
	cin>>a>>b>>c>>d;
	a=a+2; b=b+2; c=c+2; d=d+2;//都加2 是因为马可能在最上面的一行,或者左面,+2让起点从2开始就不用考虑边界问题,所以后面循环也从2开始
	q[c-2][d-1]=1; q[c-1][d-2]=1;//走一次能到的位置
	q[c+2][d-1]=1; q[c+1][d-2]=1;
	q[c+2][d+1]=1; q[c+1][d+2]=1;
	q[c-2][d+1]=1; q[c-1][d+2]=1;
    q[c][d]=1;//马的位置
	dp[1][2]=1; //因为都是0,所以把起点上面或者左面的定位1
	for(int i=2;i<=a;i++)
	{
		for(int j=2;j<=b;j++)
		{
			if(q[i][j]==1)
			{
				dp[i][j]=0;  continue;
			}
			dp[i][j]=dp[i-1][j]+dp[i][j-1];
		}
	}
	cout<<dp[a][b];
}

P1028 数的计算

题目描述

给定一个数,可以在后面加不大于前面数一半的数,一共有多少种情况

思路

偶数的时候就比如,6的情况数就是5的情况数加3的情况数,因为5的情况数是到2,少了3 的所以加上3的(手动模拟非常容易理解);奇数的时候等于前面以为的偶数

代码

void solve()
{
	int n;
    cin>>n;
	int a[1000]={1,1};//预处理,为后面做准备,此数组用来储存有多少情况
	for(int i=2;i<=n;i++)
	{
		if(i%2==0) a[i]=a[i-1]+a[i/2];//偶数
		else a[i]=a[i-1];//奇数
	}
	cout<<a[n];	//最后a[n]就是所求结果
}

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值