鱼C论坛

 找回密码
 立即注册
查看: 1439|回复: 2

广度优先搜索

[复制链接]
发表于 2023-11-22 09:18:01 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

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

x
描述
有n(n<=10)级楼梯,每次只允许跨1步、2步,走完这n级楼梯,有多少种走法?输出所有的走法。

例如n=4时,有5种走法:22、111、121、211、1111

输出的顺序要求,先输出跨步数少的走法,再输出跨步多的走法,当跨部数相同时,按字典序从小到大输出。

输入
一个正整数n(n<=10)
输出
多行,每行是由1、2构成的数字序列,表示一种走法。先输出跨步数少的走法,再输出跨步多的走法,当跨部数相同时,按字典序从小到大输出
样例输入
4
样例输出
22
112
121
211
1111
提示
可以用广度优先搜索
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-11-22 09:18:06 | 显示全部楼层
  1. from collections import deque

  2. def bfs(n):
  3.     result = []
  4.     queue = deque([(('', 0))])  # (当前走法, 当前位置)
  5.     while queue:
  6.         path, pos = queue.popleft()
  7.         if pos == n:
  8.             result.append(path)
  9.         if pos + 1 <= n:
  10.             queue.append((path + '1', pos + 1))
  11.         if pos + 2 <= n:
  12.             queue.append((path + '2', pos + 2))
  13.     result.sort(key=lambda x: (len(x), x))
  14.     return result

  15. n = 4
  16. result = bfs(n)
  17. for r in result:
  18.     print(r)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-11-22 13:25:40 | 显示全部楼层
  1. #include <iostream>
  2. #include <vector>
  3. #include <string>
  4. #include <algorithm>
  5. using namespace std;
  6. vector<string> paths;
  7. int n;
  8. bool cmp(string a, string b) {
  9.         if(a.length() != b.length()) return a.length() < b.length();
  10.         return a < b;
  11. }
  12. int sum_(string a) {
  13.         int ans = 0;
  14.         for(int i=0; i<a.size(); ++i) ans += (a[i]-'0');
  15.         return ans;
  16. }
  17. void bfs(vector<string>& now_path) {
  18.         if(now_path.size() == 0) {
  19.                 return;
  20.         }
  21.         int x = now_path.size();
  22.         for(int i=0; i<x; ++i) {
  23.                 for(int j=1; j<=min(n-sum_(now_path[0]), 2); ++j) {
  24.                         string temp = now_path[0] + char(j+'0');
  25.                         if(sum_(temp) == n)
  26.                                 paths.push_back(temp);
  27.                         else
  28.                                 now_path.push_back(temp);
  29.                 }
  30.                 now_path.erase(now_path.begin());
  31.         }
  32.         bfs(now_path);
  33. }
  34. int main()
  35. {
  36.         vector<string> now_path;
  37.        
  38.         cin >> n;       
  39.        
  40.         if(n>0) now_path.push_back("1");
  41.         if(n>1) now_path.push_back("2");
  42.         bfs(now_path);
  43.         sort(paths.begin(), paths.end(), cmp);
  44.        
  45.         for(int i=0; i<paths.size(); ++i) {
  46.                 cout << paths[i] << endl;
  47.         }
  48.         return 0;
  49. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-21 14:42

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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