京东2019届校招实习笔试题题解

京东2019届校招实习笔试题题解

题目表述:

第一题:找匹配的奇偶数

京东2019届校招实习笔试题题解_第1张图片

第二题:找删除字符后变成回文字符串的方案组合(有点意思)

京东2019届校招实习笔试题题解_第2张图片

第三题:象棋马走日方案组合

京东2019届校招实习笔试题题解_第3张图片
京东2019届校招实习笔试题题解_第4张图片

解题思路及代码:

第一题:

这题就不写了,蛮简单的,除以2除到是奇数就可以了。

第二题:

笔试的时候没有想出来,后来别人发的答案,用的DP去做的,蛮有意思的。最小子结构是一个字符,然后扩展的时候考虑是否字符一样,通过这个来传递状态。

# include
# include
# include
# include
using namespace std;

int main()
{
    string s;
    cin>>s;
    int n = s.size();

    vector<vector<long> > dp;
    for(int i = 0; i<100; i++)
        dp.push_back(vector<long>(100, 0)); // 初始化dp矩阵为0
    //init
    for (int i = 0; i < n; i++){
        dp[i][i] = 1;
        if (i+11])
            dp[i][i+1] = 3;
        else
            dp[i][i+1] = 2;
    }
    //dp update
    for (int p = 2; p < n; ++p){
        for (int i = 0, j = p; j < n; ++i, ++j)
            if (s[i] == s[j])
                dp[i][j] = dp[i+1][j] + dp[i][j-1] + 1;//加1加的是不去头不去尾,中间去光得到空串的可能性。
            else
                dp[i][j] = dp[i+1][j] + dp[i][j-1] - dp[i+1][j-1];//减去的是重叠部分重复计算的可能性
    }
    cout<0][n-1]<

第三题:

据说暴力也能AC,直接提交输出0也可以50%。我想到的方法是递归,用步数–做结束递归的标志,递归的时候要注意判断是否越界。

#include 
using namespace std;
struct point
{
    int x;
    int y;
    int deadline;
};
long long ans = 0;
int end_x, end_y;
void digui(point pos){
    if (pos.deadline == 0 && pos.x == end_x && pos.y == end_y)
    {
        ans++;
        return;
    }
    //1
    if (pos.x - 1 >= 0 && pos.y - 2 >= 0){
        point temp;
        temp.x = pos.x - 1;
        temp.y = pos.y - 2;
        temp.deadline = pos.deadline-1;
        if (temp.deadline < 0)
            return;
        digui(temp);
    }
    //2
    if(pos.x - 2 >= 0 && pos.y - 1 >= 0){
        point temp;
        temp.x = pos.x - 2;
        temp.y = pos.y - 1;
        temp.deadline = pos.deadline - 1;
        if (temp.deadline < 0)
            return;
        digui(temp);
    }
    //3
    if(pos.x - 2 >= 0 && pos.y + 1 <= 8){
        point temp;
        temp.x = pos.x - 2;
        temp.y = pos.y + 1;
        temp.deadline = pos.deadline - 1;
        if (temp.deadline < 0)
            return;
        digui(temp);
    }
    //4
    if(pos.x - 1 >= 0 && pos.y + 2 <= 8){
        point temp;
        temp.x = pos.x - 1;
        temp.y = pos.y + 2;
        temp.deadline = pos.deadline - 1;
        if (temp.deadline < 0)
            return;
        digui(temp);
    }
    //5
    if(pos.x + 1 <= 8 && pos.y + 2 <= 8){
        point temp;
        temp.x = pos.x + 1;
        temp.y = pos.y + 2;
        temp.deadline = pos.deadline - 1;
        if (temp.deadline < 0)
            return;
        digui(temp);
    }
    //6
    if(pos.x + 2 <= 8 && pos.y + 1 <= 8){
        point temp;
        temp.x = pos.x + 2;
        temp.y = pos.y + 1;
        temp.deadline = pos.deadline - 1;
        if (temp.deadline < 0)
            return;
        digui(temp);
    }
    //7
    if(pos.x + 2 <= 8 && pos.y - 1 >= 0){
        point temp;
        temp.x = pos.x + 2;
        temp.y = pos.y - 1;
        temp.deadline = pos.deadline - 1;
        if (temp.deadline < 0)
            return;
        digui(temp);
    }
    //8
    if(pos.x + 1 <= 8 && pos.y - 2 >= 0){
        point temp;
        temp.x = pos.x + 1;
        temp.y = pos.y - 2;
        temp.deadline = pos.deadline - 1;
        if (temp.deadline < 0)
            return;
        digui(temp);
    }


}
int _tmain(int argc, _TCHAR* argv[])
{
    int t;
    cin >> t;
    int i = 0;
    for (i = 0; i < t;i++){
        int k;
        cin >> k;

        cin >> end_x >> end_y;
        point start;
        start.x = 0;
        start.y = 0;
        start.deadline = k;
        digui(start);
        printf("%lld", ans%10000000007);

    }
    return 0;
}

你可能感兴趣的:(Algorithm,各类校招笔试题解)