社区讨论

递归为什么不正确!!!

P1002[NOIP 2002 普及组] 过河卒参与者 2已保存回复 3

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
3 条
当前快照
1 份
快照标识符
@lo3hed3t
此快照首次捕获于
2023/10/24 06:40
2 年前
此快照最后确认于
2023/10/24 06:40
2 年前
查看原帖

到底是哪错了!!!

CPP
#include<iostream>
#include<algorithm>
using namespace std;

bool check(int x, int y,int m, int n){
    return ((x-m)*(x-m)+
    (y-n)*(y-n))!=5 && !(x == m || y == n);
}
long long numOfLines(int m,int n,int h_m,int h_n)
{
    if(!check(m,n,h_m,h_n))
    {
        return 0;
    }
    else if(m == 0 && n == 0)
    {
        return 1;
    }
    else if(m == 0 && n != 0)
    {
        return numOfLines(m,n-1,h_m,h_n);
    }
    else if(m != 0 && n == 0)
    {
        return numOfLines(m-1,n,h_m,h_n);
    }
    else
    {
        return numOfLines(m,n-1,h_m,h_n) + numOfLines(m,n-1,h_m,h_n);
    }
}
int main(){
    int m,n,h_m,h_n;
    cin >> m >> n >> h_m >> h_n;
    cout << numOfLines(m,n,h_m,h_n);
    return 0;
}

回复

3 条回复,欢迎继续交流。

正在加载回复...