开心星人 2022-04-08 23:45
浏览 98
已结题

这一题用bfs怎么写,我写的哪里错了

最少次数
有一个整数 A=2021,每一次,可以将这个数加 1 、减 1 或除以 2,其中除以 2 必须在数是偶数的时候才允许。
例如,2021 经过一次操作可以变成 2020、2022。
再如,2022 经过一次操作可以变成 2021、2023 或 1011。
请问,2021 最少经过多少次操作可以变成 1。

#include<bits/stdc++.h>
typedef long long ll;
using namespace std;
int ans=1e9;
int vis[10000];
void dfs(int n,int time){
    vis[n]=1;
    if(n==1){
        ans=min(time,ans);
        return;
    }
    if(n%2==0&&vis[n/2]==0){
        dfs(n/2,time+1);
    }
    if(vis[n+1]==0){
        dfs(n+1,time+1);
    }
    if(vis[n-1]==0){
        dfs(n-1,time+1);
    }
}
int main(){    
    dfs(2021,0);
    cout<<ans<<endl;
    return 0;
} 

  • 写回答

1条回答 默认 最新

  • 开心星人 2022-04-08 23:54
    关注

    打错了,用dfs怎么写

    评论

报告相同问题?

问题事件

  • 系统已结题 4月16日
  • 创建了问题 4月8日

悬赏问题

  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来
  • ¥50 comfyui下连接animatediff节点生成视频质量非常差的原因
  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置