当前位置: 首页 > news >正文

蓝桥杯双周赛算法心得——数树数(dfs)

大家好,我是晴天学长,一个简单的dfs思想,需要的小伙伴可以关注支持一下哦!后续会继续更新的。


1) .数树数

在这里插入图片描述


2) .算法思路

代码的主要逻辑是:

1.使用Scanner读取输入的整数n和q,其中n表示测试用例的数量,q表示每个测试用例的步数。
2.使用循环遍历每个测试用例:
3.读取一个字符串s,该字符串由字符’L’和’R’组成,表示树的结构。
4.初始化ans为0,用于记录树的数目。
5.调用dfs方法进行深度优先搜索,传入参数s、初始的ans和步数1。
6.输出搜索结果并进行下一个测试用例的处理。
7.dfs方法是递归的深度优先搜索函数,它根据输入的字符串s和当前的ans和步数来计算树的数目。

具体逻辑如下:

1.如果当前步数对应的字符是’L’,则树的数目按照公式(ans-1)*2+1计算。
2.如果当前步数对应的字符是’R’,则树的数目按照公式(ans-1)*2+2计算。
3.如果当前步数是字符串s的最后一个字符的位置,则返回计算得到的树的数目。
4.增加步数step的值,并递归调用dfs方法,传入更新后的ans和步数。
5.返回递归调用的结果。


3).代码示例

package LanQiaoTest.枚举;import java.util.Scanner;public class 数树数 {static int ans = 0;public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();int q = scanner.nextInt();for (int i = 0; i < q; i++) {String s = scanner.next();ans= 0;System.out.println(dfs(s, 1, 0));}}public static int dfs(String s, int ans, int step) {if (s.charAt(step) == 'L') {if (ans == 1) {ans = Math.max(1, ans-1);}else {ans=(ans-1)*2+1;}} else {ans = (ans-1)*2+2;}if (step==s.length()-1){return ans;}step++;ans=dfs(s,ans,step);return ans;}
}

5).总结

  • dfs的正确步骤。
  • 变量的正确赋值。
http://www.lryc.cn/news/193311.html

相关文章:

  • 综述:大规模小目标检测
  • ORACLE XXX序列 goes below MINVALUE 无法实例化的处理办法
  • 6款流程图制作软件:一站式指南
  • 第三章:Python中的序列(上)
  • 使用.NET实现WOL唤醒远程开机
  • 适用于 Golang 的任务调度程序 AGScheduler
  • 【HCIP】HCIA复习
  • 【Python小项目之Tkinter应用】【实用工具】实现手写签名器,可选线条粗细,支持清空、撤销、恢复功能,可将写好的签名保存成图片
  • Jenkins集成newman
  • Excel——对其他工作表和工作簿的引用
  • 如何正确的防止服务器被攻击?103.216.153.x
  • 本地生活将成快手新的营收增长点
  • 信息化工程测试验收管理制度
  • 解决vue2设置cross-env设置环境变量不起作用问题
  • Pandas 入门指南
  • 单链表---结构体实现
  • Linux Shell 编程基础语法汇总
  • github 中关于Pyqt 的module view 操作练习
  • 【操作系统】磁臂黏着现象
  • 面试题-React(十二):React中不可变数据的力量
  • conda 创建虚拟环境
  • Java的HTML转义工具
  • Flask (Jinja2) 服务端模板注入漏洞复现
  • file_get_contents 与curl 的对比
  • 两个el-date-picker进行互相关联
  • python openai playground使用教程
  • DOCKER本地仓库
  • python写着玩
  • K8s Kubernetes Namespave Pod Label Deployment Service 实战
  • SpringBoot使用随机端口启动