[蓝桥杯 | 暴搜] 学会暴搜之路

虽然会调侃蓝桥杯是暴力求解的,但是本弱弱不会搜,不知道如何搜,于是写下这篇碎碎念,记录看到过的,惊艳自己的暴搜。

小总结

题目特征:很复杂的排列组合

说是暴力,其实就是枚举罢了,再利用dfs一步一步解决。基本上题目一个限制就让函数带一个形参,还得明确最后的搜索结束条件。

搜索策略:dfs bfs 贪心??

题目示例

分糖果

题解

#include <iostream>
using namespace std;
int ans=0,a=9,b=16;

 void dfs(int x,int m,int n){//x为小朋友编号,m,n为两种糖果剩余数量
  if(x>7){
    if(m==0&&n==0){
      ans++;
    }
    return ;
  }

  for(int i=0;i<=m;i++){
    for(int j=0;j<=n;j++){
      if(i+j>=2&&i+j<=5){
        dfs(x+1,m-i,n-j);
       //次数不用恢复现场,因为并未改变当前深度糖果数量
      }
    }
  }
}
int main()
{
 
  dfs(1,9,16);
  cout<<ans;
  return 0;
}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
蓝桥杯是中国最大的IT技能竞赛之一,索算法是其中一个常见的考点。在蓝桥杯中,索算法主要包括深度优先索(DFS)和广度优先索(BFS)两种常见的算法。 深度优先索(DFS)是一种用于遍历或索树或图的算法。它从根节点开始,沿着一条路径一直向下索,直到达到叶子节点或无法继续向下索为止,然后回溯到上一个节点,继续索其他路径。DFS通常使用递归或栈来实现。 广度优先索(BFS)是一种用于遍历或索树或图的算法。它从根节点开始,逐层地向外扩展索,先访问离根节点最近的节点,然后是离根节点更远的节点。BFS通常使用队列来实现。 在Python中,可以使用递归或者队列来实现DFS和BFS算法。以下是一个简单的DFS和BFS的示例代码: DFS算法示例代码: ```python def dfs(graph, start, visited): visited.add(start) print(start, end=" ") for neighbor in graph[start]: if neighbor not in visited: dfs(graph, neighbor, visited) # 示例图的邻接表表示 graph = { 'A': ['B', 'C'], 'B': ['A', 'D', 'E'], 'C': ['A', 'F'], 'D': ['B'], 'E': ['B', 'F'], 'F': ['C', 'E'] } visited = set() dfs(graph, 'A', visited) ``` BFS算法示例代码: ```python from collections import deque def bfs(graph, start): visited = set() queue = deque([start]) visited.add(start) while queue: node = queue.popleft() print(node, end=" ") for neighbor in graph[node]: if neighbor not in visited: queue.append(neighbor) visited.add(neighbor) # 示例图的邻接表表示 graph = { 'A': ['B', 'C'], 'B': ['A', 'D', 'E'], 'C': ['A', 'F'], 'D': ['B'], 'E': ['B', 'F'], 'F': ['C', 'E'] } bfs(graph, 'A') ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值