m0_71611766 2022-06-21 09:21 采纳率: 50%
浏览 88
已结题

用c++解决下面这个问题。

马走日问题1)问题描述。如下图所示:马从(0,0)出发,只能往右(右上或右下)跳,从(0,0)点到(8,4)点,这个区域内有多少种不同的路径,并打印出各种路径。

  • 写回答

2条回答 默认 最新

  • 关注

    一共37种

    img

    
    #include <stdio.h>
    
    int stackrow[100];
    int stackcol[100];
    int ps = 0;
    
    int count = 0;
    
    void horse(int row, int col);
    void push(int row, int col);
    void pop();
    void output_result();
    
    int main(void)
    {
        horse(0, 0);
    
        return 0;
    }
    
    /* 函数功能:当前马调到row行col列
     *
     * 参数:row--行,col--列
     */
    void horse(int row, int col) {
        push(row, col);
        if(row == 8 && col == 4)
            output_result();
        if(row < 0 ||col < 0|| row > 8 || col > 4) {
            ;
        } else {
            horse(row +2, col + 1);
            horse(row +1, col + 2);
            horse(row + 1, col -2);
            horse(row + 2, col - 1);
    
        }
        pop();
    }
    
    void push(int row, int col) {
        stackrow[ps] = row;
        stackcol[ps] = col;
        ps++;
    }
    
    void pop() {
        ps--;
    }
    
    void output_result() {
        count++;
        int i;
        printf("result %d\n", count);
        for(i=0; i<ps-1; i++) {
            printf("(%d,%d)->",  stackrow[i], stackcol[i]);
        }
        printf("(%d,%d)",  stackrow[ps-1], stackcol[ps-1]);
        printf("\n");
    
    }
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 6月29日
  • 已采纳回答 6月21日
  • 赞助了问题酬金20元 6月21日
  • 创建了问题 6月21日

悬赏问题

  • ¥15 yolov8边框坐标
  • ¥15 matlab中使用gurobi时报错
  • ¥15 这个主板怎么能扩出一两个sata口
  • ¥15 不是,这到底错哪儿了😭
  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂