蓝桥杯双周赛算法心得——数树数(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).代码示例

java 复制代码
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的正确步骤。
  • 变量的正确赋值。
相关推荐
2013092416275 小时前
1968年 Hart, Nilsson, Raphael 《最小成本路径启发式确定的形式基础》A* 算法深度研究报告
人工智能·算法
如何原谅奋力过但无声5 小时前
【力扣-Python-滑动窗口经典题】567.字符串的排列 | 424.替换后的最长重复字符 | 76.最小覆盖子串
算法·leetcode
玄冥剑尊6 小时前
贪心算法进阶
算法·贪心算法
玄冥剑尊6 小时前
贪心算法深化 I
算法·贪心算法
52Hz1186 小时前
力扣73.矩阵置零、54.螺旋矩阵、48.旋转图像
python·算法·leetcode·矩阵
BHXDML6 小时前
第一章:线性回归& 逻辑回归
算法·逻辑回归·线性回归
iAkuya7 小时前
(leetcode)力扣100 二叉搜索树种第K小的元素(中序遍历||记录子树的节点数)
算法·leetcode·职场和发展
Remember_9938 小时前
【LeetCode精选算法】滑动窗口专题二
java·开发语言·数据结构·算法·leetcode
Gorgous—l8 小时前
数据结构算法学习:LeetCode热题100-动态规划篇(下)(单词拆分、最长递增子序列、乘积最大子数组、分割等和子集、最长有效括号)
数据结构·学习·算法
北京地铁1号线9 小时前
2.3 相似度算法详解:Cosine Similarity 与 Euclidean Distance
算法·余弦相似度