bfs宽搜

[复制链接]
发表于 2024-8-1 13:06:58 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

×
Problem - B - Codeforces


  1. #include <bits/stdc++.h>
  2. using namespace std;
  3. typedef long long LL;
  4. typedef pair<int,int> PII;
  5. const int N=1e4+10;
  6. int q[N], hh,tt;
  7. int d[N];
  8. int n,m;
  9. int bfs(int u)
  10. {
  11.         memset(d,-1,sizeof d);
  12.         q[0]=u;
  13.         d[u]=0;
  14.         while(hh<=tt){
  15.                 int t=q[hh++];
  16.                 if(t==m) return d[t];
  17.                 int j=t-1;
  18.                 if(j>=0 && j<=10000 && d[j]==-1){
  19.                         q[++tt]=j;
  20.                         d[j]=d[t]+1;
  21.                 }
  22.                 j=t*2;
  23.                 if(j>=0 && j<=10000 && d[j]==-1){
  24.                         q[++tt]=j;
  25.                         d[j]=d[t]+1;
  26.                 }
  27.         }
  28. }
  29. void solve()
  30. {
  31.         cin>>n>>m;
  32.         int cnt=0;
  33.         if(n>=m) cnt=n-m;
  34.         else {
  35.                 cnt=bfs(n);
  36.         }
  37.         cout<<cnt<<'\n';
  38.        
  39. }
  40. int main()
  41. {
  42.         int T;
  43. //        cin>>T;
  44.         T=1;
  45.         while(T--){
  46.                 solve();
  47.         }
  48.         return 0;
  49. }
复制代码


免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
继续阅读请点击广告
回复

使用道具 举报

© 2001-2025 Discuz! Team. Powered by Discuz! X3.5

GMT+8, 2025-7-3 00:23 , Processed in 0.078092 second(s), 29 queries 手机版|qidao123.com技术社区-IT企服评测▪应用市场 ( 浙ICP备20004199 )|网站地图

快速回复 返回顶部 返回列表