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]就是所求结果
}