关于DFS几道比较基础的题

本文介绍了四道基于深度优先搜索(DFS)的基础题目,包括FatMouse奶酪最大值问题、字符全排列、走迷宫找积水池塘数量以及机器人走棋盘的路径计数。解题思路涵盖如何利用DFS解决不同场景下的问题,如记忆化搜索、路径搜索等。
摘要由CSDN通过智能技术生成
  1. 题目一 FatMouse and Cheese
    题目大意就是说有一个老鼠在N*N的网格当中每一步最多只能走K格 并且由于猫的存在每一次老鼠的移动都必须比路径上一个网格收集的奶酪多 问这条路径上老鼠收集的奶酪最大值
Sample Input
3 1
1 2 5
10 11 6
12 12 7
-1 -1
Sample Output
37

PS: 终点的位置不是固定的 满足上下左右都不存在比当前更大的网格的条件 即四周都比当前网格值小

#include<bits/stdc++.h>
using namespace std;

const int maxn=105;
int n,k,nx,ny;
int vis[maxn][maxn],dp[maxn][maxn];
int dx[4]={1,0,-1,0};
int dy[4]={0,1,0,-1};
int dfs(int x,int y)
{
    int i,j,nx,ny,ans=0;
    if(dp[x][y])
        return dp[x][y];//联系到第二个return 即已经进行赋值表示找到了最大路径
    for(i=0;i<4;i++)
    {
        for(j=1;j<=k;j++)
        {
            nx=x+j*dx[i];//每次移动1~k个网格
            ny=y+j*dy[i];
            if(nx>0&&nx<=n&&ny>0&&ny<=n&&vis[nx][ny]>vis[x][y])
            {
                ans=max(ans,dfs(nx,ny));//一直往(nx,ny)的方向递归找最大路径
            }
        }
    }
    return dp[x][y]=ans+vis[x][y];//已经走到了终点加上终点的值
}
int main()
{
    int i,j;
    while(scanf("%d%d",&n,&k)!=EOF)
    {
        if(n==-1&&k==-1)
            break;
        memset(dp,0,sizeof(dp));
        for(i=1;i<=n;i++)
            for(j=1;j<=n;j++)
                scanf("%d",&vis[i][j]);
        printf("%d\n",dfs(1,1));
    }
    return 0;
}
  1. 题目二 字符的全排列问题 有n个字符 请你输出该n个字符的全排列
Sample Input
1
abc
Sample Output
a b c
a c b
b a c
b c a
c a b
c b a
#include<stdio.h>
#include<string.h>

int n;
char  a[15];
char re[15];
int vis[15];
void dfs(int step)
{
    int i;
    if(step==n+1)//判断边界
    {
        for(i=1;i<=n;i++)
            
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值