算法题目整合

news2025/1/10 11:59:31

文章目录

  • 121. 小红的区间翻转
  • 142. 两个字符串的最小 ASCII 删除总和
  • 143. 最长同值路径
  • 139.完美数
  • 140. 可爱串
  • 141. 好二叉树

121. 小红的区间翻转

小红拿到了两个长度为 n 的数组 a 和 b,她仅可以执行一次以下翻转操作:选择a数组中的一个区间[i, j],(i != j),将它们翻转。例如,对于 a = [2,3,4,1,5,6],小红可以选择左闭右闭区间[2,4],数组 a 则变成[2,3,5,1,4,6]。

小红希望操作后 a 数组和 b 数组完全相同。请你告诉小红有多少种操作的方案数。

初始 a 数组和 b 数组必定不相同。
输入描述

第一行输入一个正整数 n,代表数组的长度;
第二行输入 n 个正整数 ai; 
第三行输入 n 个正整数 bi。
输出描述
选择区间的方案数。

输入示例

4
1 2 3 1
1 3 2 1

输出示例

2

提示信息

数据范围
1 ≤ n, ai ,bi ≤ 103
在示例中:
将 1 2 3 1 中的 2 3 进行翻转,得到 1 3 2 1。
将 1 2 3 1 整个进行翻转,得到 1 3 2 1。
所以最终结果是 2。

思路:考虑先找到满足条件的最大left索引和最小right索引,然后进行循环:每次循环left–,right++,如果说A[left]==B[right],说明翻转后还是相同,直到两者不等,那么此时就可以break了。

import java.util.*;
class Main{
    public static void main(String[] args){
        Scanner scanner = new Scanner(System.in);
        int len = scanner.nextInt();
        int[] A = new int[len], B = new int[len];
        for(int i = 0; i < len; i++){
            A[i] = scanner.nextInt();
        }
        for(int i = 0; i < len; i++){
            B[i] = scanner.nextInt();
        }
        System.out.println(cal(A, B, len));
    }
    
    private static int cal(int[] A, int[] B, int len){
        int start = 0, end = len - 1;
        //定位到A与B第一个不相同的地方,这个时候需要考虑进行翻转了
        while(A[start] == B[start]){
            start++;
        }
        while(A[end] == B[end]){
            end--;
        }
        //找到满足条件的最大left索引和最小right索引
        int left = start, right = end;
        while(left <= end && right >= start){
            if(A[left] != B[right])  return 0;
            left++;
            right--;
        }
        int res = 1;
        int l = start - 1, r = end + 1;
        //进行循环
        while(l >= 0 && r < len){
            if(A[l] != B[r]){
                break;
            }else{
                res++;
            }
            l--;
            r++;
        }
        return res;
    }
}

142. 两个字符串的最小 ASCII 删除总和

题目描述

给定两个字符串 s1 和 s2(0 <= s1.length, s2.length <= 1000),返回使两个字符用相等所需删除字符的 ASCLL 值的最小和。 
s1 和 s2 由小写英文字母组成。

输入描述

输入共两行,每行一个字符串。

输出描述

输出一个正整数,表示使两个字符用相等所需删除字符的 ASCLL 值的最小和。

输入示例

sea
eat

输出示例

231

提示信息

解释:在“sea”中删除“s”并将"s”的值(115)加入总和。 
在"eat”中删除“t“并将116 加入总和。 
结束时,两个字符串相等,115+116 =231 就是符合条件的很小和。

思路:动态规划:记 d p [ i ] [ j ] dp[i][j] dp[i][j]为str1到str2最小 ASCII 删除总和,于是有转移方程
d p [ i ] [ j ] = d p [ i − 1 ] [ j − 1 ] , i f s t r 1 [ i − 1 ] = = s t r 2 [ j − 1 ] d p [ i ] [ j ] = m i n ( d p [ i − 1 ] [ j ] + s t r 1 ( i − 1 ) , d p [ i ] [ j − 1 ] + s t r 2 ( j − 1 ) ) dp[i][j]=dp[i-1][j-1],\quad if\quad str1[i-1]==str2[j-1] \\ dp[i][j] =min(dp[i-1][j]+str1(i-1),dp[i][j-1]+str2(j-1)) dp[i][j]=dp[i1][j1],ifstr1[i1]==str2[j1]dp[i][j]=min(dp[i1][j]+str1(i1),dp[i][j1]+str2(j1))
还有边界条件
d p [ 0 ] [ 0 ] = 0 d p [ i ] [ 0 ] = d p [ i − 1 ] [ 0 ] + s t r 1 ( i − 1 ) d p [ 0 ] [ j ] = d p [ 0 ] [ j − 1 ] + s t r 2 ( j − 1 ) dp[0][0]=0 dp[i][0]=dp[i-1][0]+str1(i-1)\\ dp[0][j]=dp[0][j-1]+str2(j-1) dp[0][0]=0dp[i][0]=dp[i1][0]+str1(i1)dp[0][j]=dp[0][j1]+str2(j1)
然后空间优化方面,由于 d p [ i ] [ j ] dp[i][j] dp[i][j]只与 d p [ i − 1 ] [ j ] , d p [ i ] [ j − 1 ] , d p [ i − 1 ] [ j − 1 ] dp[i-1][j],dp[i][j-1],dp[i-1][j-1] dp[i1][j]dp[i][j1]dp[i1][j1]有关,所以可以优化成一维数组。
d p [ i − 1 ] [ j ] dp[i-1][j] dp[i1][j]就是 d p [ j ] dp[j] dp[j]
d p [ i ] [ j ] dp[i][j] dp[i][j]就是 d p [ j ] dp[j] dp[j]
d p [ i ] [ j − 1 ] dp[i][j-1] dp[i][j1]就是 d p [ j − 1 ] dp[j-1] dp[j1]
d p [ i − 1 ] [ j − 1 ] dp[i-1][j-1] dp[i1][j1]就需要先利用 p r e v prev prev记录 d p [ i − 1 ] [ 0 ] dp[i-1][0] dp[i1][0],再在内层循环时用 t e m p temp temp记录 d p [ i − 1 ] [ j − 1 ] dp[i-1][j-1] dp[i1][j1]

import java.util.*;
class Main{
    public static void main (String[] args) {
        Scanner scanner = new Scanner(System.in);
        String str1 = scanner.next();
        String str2 = scanner.next();
        System.out.println(AsciiSum(str1, str2));
    }
    private static int AsciiSum(String str1, String str2){
        int m = str1.length();
        int n = str2.length();
        int[] dp = new int[n + 1];
        for(int j = 1; j <= n; j++){
            dp[j] = dp[j - 1] + str2.charAt(j - 1);
        }
        for(int i = 1; i <= m; i++){
            int prev = dp[0];
            dp[0] += str1.charAt(i - 1);
            for(int j = 1; j <= n; j++){
                int temp = dp[j];
                if(str1.charAt(i - 1) == str2.charAt(j - 1)){
                    dp[j] = prev;
                }else{
                    dp[j] = Math.min(dp[j] + str1.charAt(i-1),dp[j-1]+str2.charAt(j-1));
                }
                prev = temp;
            }
        }
        return dp[n];
    }
}

143. 最长同值路径

题目描述

给定一个二叉树的 root ,返回最长的路径的长度,这个路径中的每节点具有相同值。
这条路径可以经过也可以不经过根节点。两个节点之间的路径长度 由它们之间的边数表示。 
树的节点数的范围是 [0,10^4] -1000 <= Node.val <= 1000
树的深度将不超过 18 层

输入描述

输入共两行,第一行是一个整数 n,表示第二行的字符串数。
第二行包含 n 个字符串,空格隔开,数字的字符串代表该节点存在,并且值为数字,null 代表是一个空结点。

输出描述

输出一个正整数,代表最长路径长度。

输入示例

7
5 4 5 1 1 null 5

输出示例

2

在这里插入图片描述这题有两个难点,第一个自然就是找到最长路径长度,但另一个难点是如何构造需要的二叉树,所以这个问题可以拆成两个部分:

  1. 根据输入构建二叉树
  2. 根据二叉树找到最长路径长度
    上面两点分别对应了deSerialize方法和dfs方法,两个方法本身并不算复杂,只不过需要熟练掌握队列的使用。
import java.util.*;
class Main{
    static int max;
    public static void main (String[] args) {
        max = 0;
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        sc.nextLine();
        String str = sc.nextLine();
        TreeNode root = deSerialize(str);
        dfs(root);
        System.out.println(max);
    }
    private static int dfs(TreeNode node){
        if(node == null)  return 0;
        int cur = 0, res = 0, left = dfs(node.left), right = dfs(node.right);
        int left1 = 0, right1 = 0;
        if(node.left != null && node.val == node.left.val){
            left1 = left + 1;
        }
        if(node.right != null && node.val == node.right.val){
            right1 = right + 1;
        }
        max = Math.max(max, left1 + right1);
        return Math.max(left1, right1);
    }
    private static TreeNode deSerialize(String s){
        String[] vals = s.split(" ");
        TreeNode root = new TreeNode(Integer.parseInt(vals[0]));
        Queue<TreeNode> queue = new LinkedList<>();
        queue.offer(root);
        int i = 1;
        while(!queue.isEmpty()){
            TreeNode node = queue.poll();
            if(i < vals.length && !vals[i].equals("null")){
                node.left = new TreeNode(Integer.parseInt(vals[i]));
                queue.offer(node.left);
            }
            i++;
            if(i < vals.length && !vals[i].equals("null")){
                node.right = new TreeNode(Integer.parseInt(vals[i]));
                queue.offer(node.right);
            }
            i++;
        }
        return root;
    }
}
class TreeNode{
    TreeNode left;
    TreeNode right;
    int val;
    TreeNode(){}
    TreeNode(int val){
        this.val = val;
    }
}

139.完美数

题目描述

小红定义一个数为“完美数”,当且仅当该数仅有一个非零数字。例如 5000, 4, 1, 10, 200 都是完美数。 

小红拿到了一个大小为 n(2 <= n <= 2000)的数组 a,她希望选择数组中的两个元素(1 <= a[i] <= 10^9),满足它们的乘积为完美数。 小红想知道,共有多少种不同的取法?

输入描述

第一行输入一个整数 n,表示数组大小。 

第二行输入 n 个整数,整数之间用空格隔开,表示数组中的元素。

输出描述

输出一个整数,表示取法个数。

输入示例

4
25 2 1 16

输出示例

3

提示信息

25 * 2 = 50; 2 * 1 = 2; 25 * 16 = 400。

难度不大,将long来存储乘积结果并用String来进行0的判断是关键。

import java.util.*;
class Main{
    public static void main (String[] args) {
        Scanner sc = new Scanner(System.in);
        int res = 0;
        int n = sc.nextInt();
        long[] nums = new long[n];
        for(int i = 0; i < n; i++){
            nums[i] = sc.nextInt();
        }
        for(int i = 0; i < n; i++){
            for(int j = i + 1; j < n; j++){
                long ans = nums[i] * nums[j];
                if(isValid(ans))  res++;
            }
        }
        System.out.println(res);
    }
    private static boolean isValid(long ans){
        String s = String.valueOf(ans);
        for(int i = 1; i < s.length(); i++){
            if(s.charAt(i) != '0'){
                return false;
            }
        }
        return true;
    }
}

140. 可爱串

题目描述

我们定义子序列为字符串中可以不连续的一段,而子串则必须连续。
例如 rderd 包含子序列 "red”,且不包含子串"red”,因此该字符串为可爱串。 

小红想知道,长度为 n(3 <= n <= 10 ^ 5)的、仅由 'r''e''d' 三种字母组成的字符串中,有多少是可爱串?
 答案请对 10 ^ 9 + 7 取模。

输入描述

输入共一行,包含一个正整数 n

输出描述

输出一个正整数,代表可爱串的数量

输入示例

4

输出示例

3

提示信息

"reed"、"rerd"、"rded"
import java.util.*;

public class Main{
    static long MOD = (long) (1e9 + 7);
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        int n = in.nextInt();
        long[] dp1 = new long[n + 1];
        long[] dp2 = new long[n + 1];
        long[] dp3 = new long[n + 1];
        // 可爱串的个数 = 包含“red”子序列的方案个数 - 包含“red”子串的方案个数

        // dp1[i]表示长度为i的包含“red”子串的方案个数
        for (int i = 3; i <= n; i++) {
            dp1[i] = (3 * dp1[i - 1] + pow(3,i - 3) - dp1[i - 3] + MOD) % MOD;
        }
        // dp2[i]表示长度为i的包含“re”子序列的方案个数
        for (int i = 2; i <= n; i++) {
            dp2[i] = ((2 * dp2[i - 1]) + (i - 1) * pow(2, i - 2) + MOD) % MOD;
        }
        // dp3[i]表示长度为i的包含“red”子序列的方案个数
        for (int i = 3; i <= n; i++) {
            dp3[i] = (3 * dp3[i - 1] + dp2[i - 1] + MOD) % MOD;
        }

        System.out.println(dp3[n] - dp1[n]);
    }
    private static long pow(long x, long n) {
        long res = 1;
        while (n > 0) {
            if ((n & 1) == 1) {  // 如果 n 是奇数
                res = res * x % MOD;
            }
            x = x * x % MOD;
            n >>= 1;  // n 右移一位,相当于除以 2
        }
        return res;
    }
}

141. 好二叉树

题目描述

小红定义一个二叉树为“好二叉树”,当且仅当该二叉树所有节点的孩子数量为偶数(0 或者 2)。 
小红想知道,n(1<= n <=3000)个节点组成的好二叉树,共有多少种不同的形态? 
答案请对 10 ^ 9 + 7 取模。

输入描述

输入一个正整数 n

输出描述

输出一个正整数,代表好二叉树的数量

输入示例

5

输出示例

2

思路:动态规划,一个二叉树除了根节点可以分为左子树和右子树,设分别有 j j j个和 k − j k-j kj个,其中 k = i − 1 k=i-1 k=i1 j j j遍历每一个奇数即可。

import java.util.*;
class Main{
    static long MOD = (long)(1e9 + 7);
    public static void main (String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        long[] dp = new long[3001];
        dp[1] = dp[3] = 1;
        for(int i = 5; i <= n; i += 2){
            for(int j = 1, k = i - 1; j < k; j += 2){
                dp[i] += (dp[j] * dp[k-j]) % MOD;
                dp[i] %= MOD;
            }
        }
        System.out.println(dp[n]);
    }
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1932954.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Apache AGE的MATCH子句

MATCH子句允许您在数据库中指定查询将搜索的模式。这是检索数据以在查询中使用的主要方法。 通常在MATCH子句之后会跟随一个WHERE子句&#xff0c;以添加用户定义的限制条件到匹配的模式中&#xff0c;以操纵返回的数据集。谓词是模式描述的一部分&#xff0c;不应被视为仅在匹…

OpenAI训练数据从哪里来、与苹果合作进展如何?“ChatGPT之母”最新回应

7月9日&#xff0c;美国约翰霍普金斯大学公布了对“ChatGPT之母”、OpenAI首席技术官米拉穆拉蒂&#xff08;Mira Murati&#xff09;的采访视频。这场采访时间是6月10日&#xff0c;访谈中&#xff0c;穆拉蒂不仅与主持人讨论了OpenAI与Apple的合作伙伴关系&#xff0c;还深入…

20.x86游戏实战-远线程注入的实现

免责声明&#xff1a;内容仅供学习参考&#xff0c;请合法利用知识&#xff0c;禁止进行违法犯罪活动&#xff01; 本次游戏没法给 内容参考于&#xff1a;微尘网络安全 工具下载&#xff1a; 链接&#xff1a;https://pan.baidu.com/s/1rEEJnt85npn7N38Ai0_F2Q?pwd6tw3 提…

mac M1 创建Mysql8.0容器

MySLQ8.0 拉取m1镜像 docker pull mysql:8.0创建挂载文件夹并且赋予权限 sudo chmod 777 /Users/zhao/software/dockerLocalData/mysql 创建容器并且挂载 docker run --name mysql_8 \-e MYSQL_ROOT_PASSWORDadmin \-v /Users/zhao/software/dockerLocalData/mysql/:/var/l…

2-37 基于matlab的IMU姿态解算

基于matlab的IMU姿态解算,姿态类型为四元数&#xff1b;角速度和线加速度的类型为三维向量。IMU全称是惯性导航系统&#xff0c;主要元件有陀螺仪、加速度计和磁力计。其中陀螺仪可以得到各个轴的加速度&#xff0c;而加速度计能得到x&#xff0c;y&#xff0c;z方向的加速度&a…

PDF小工具poppler

1. 简介 介绍一下一个不错的PDF库poppler。poppler的官网地址在:https://poppler.freedesktop.org/ 它是一个PDF的渲染库,顾名思义,它的用途就是读取PDF文件,然后显示到屏幕(显示到屏幕上只是一种最狭义的应用,包括使用Windows上的GDI技术显示文件内容,当然可以渲染到…

【java】力扣 合法分割的最小下标

文章目录 题目链接题目描述思路代码 题目链接 2780.合法分割的最小下标 题目描述 思路 这道题是摩尔算法的一种扩展 我们先可以找到候选人出来&#xff0c;然后去计算他在左右两边元素出现的次数&#xff0c;只有当他左边时&#xff0c;左边出现的次数2 >左边的长度&…

跨平台WPF音乐商店应用程序

目录 一 简介 二 设计思路 三 源码 一 简介 支持在线检索音乐&#xff0c;支持实时浏览当前收藏的音乐及音乐数据的持久化。 二 设计思路 采用MVVM架构&#xff0c;前后端分离&#xff0c;子界面弹出始终位于主界面的中心。 三 源码 视窗引导启动源码&#xff1a; namesp…

AI、ML、DL 和 DS 之间的区别

人工智能 数据分析 数据科学 深度学习 机器学习 神经网络 在本文中&#xff0c;我们将了解 AI&#xff08;人工智能&#xff09;、ML&#xff08;机器学习&#xff09;、DL&#xff08;深度学习&#xff09;和 DS&#xff08;数据科学&#xff09;之间的区别。这些术语经常互换…

JVM基本知识——运行空间

JVM&#xff08;Java Virtual Machine&#xff09;即Java虚拟机&#xff0c;是负责读取java字节码&#xff0c;并在实际的硬件环境中运行。 JVM可以分为三部分&#xff1a;类装载器&#xff08;ClassLoader&#xff09;子系统、内存空间、执行引擎 内存空间&#xff08;运行时…

数仓建模详解:电商案例解析(第38天)

系列文章目录 一、需求分析 二、数据仓库设计 三、数据集成与处理 四、数据仓库实施与维护 五、实例&#xff1a;电商平台数据仓库建模 六、设计过程中遇到的常见问题有哪些 文章目录 系列文章目录前言常见数仓分层架构图一、需求分析二、数据仓库设计三、数据集成与处理四、数…

海外社媒矩阵为何会被关联?如何IP隔离?

在当今的数字时代&#xff0c;社交媒体已经成为人们日常生活中不可或缺的一部分。通过社交媒体&#xff0c;人们可以与朋友互动&#xff0c;分享生活&#xff0c;甚至进行业务推广和营销。然而&#xff0c;社交媒体账号关联问题逐渐受到广泛关注。社交媒体账号为何会关联&#…

Spring MVC 的常用注解

RequestMapping 和 RestController注解 上面两个注解&#xff0c;是Spring MCV最常用的注解。 RequestMapping &#xff0c; 他是用来注册接口的路由映射。 路由映射&#xff1a;当一个用户访问url时&#xff0c;将用户的请求对应到某个方法或类的过程叫做路由映射。 Reques…

学习008-01-02 Define the Data Model and Set the Initial Data(定义数据模型并设置初始数据 )

Define the Data Model and Set the Initial Data&#xff08;定义数据模型并设置初始数据 &#xff09; This topic explains how to implement entity classes for your application. It also describes the basics of automatic user interface construction based on a da…

SAP ABAP性能优化分析工具

SAP系统提供了许多性能调优的工具&#xff0c;重点介绍下最常用几种SM50, ST05, SAT等工具&#xff1a; 1.工具概况 1.1 SM50 / SM66 - 工作进程监视器 通过这两个T-code, 可以查看当前SAP AS实例上面的工作进程&#xff0c;当某一工作进程长时间处于running的状态时&#…

现场可重构CPLD芯片应用案例—蓝牙音箱

我司英尚微提供的高性能数模混合现场可重构IC、通用可配置的模数混合芯片内部集成丰富的模拟资源和数字资源&#xff0c;可轻松替代电路中的各种标准器件&#xff0c;并按照客户要求组合成最优小型ASIC&#xff0c;缩短开发周期&#xff0c;降低成本。下面介绍LS98002现场可重构…

Kafka Producer之ACKS应答机制

文章目录 1. 应答机制2. 等级03. 等级14. 等级all5. 设置等级6. ISR 1. 应答机制 异步发送的效率高&#xff0c;但是不安全&#xff0c;同步发送安全&#xff0c;但是效率低。 无论哪一种&#xff0c;有一个关键的步骤叫做回调&#xff0c;也就是ACKS应答机制。 其中ACKS也分…

AQS详解(详细图文)

目录 AQS详解1、AQS简介AbstractQueuedSynchronizer的继承结构和类属性AQS的静态内部类Node总结AQS的实现思想总结AQS的实现原理AQS和锁的关系 2、AQS的核心方法AQS管理共享资源的方式独占方式下&#xff0c;AQS获取资源的流程详解独占方式下&#xff0c;AQS释放资源的流程详解…

Django 请求和响应

1、请求 &#xff08;1&#xff09;get请求 用户直接在浏览器输入网址&#xff0c;参数直接在url中携带 http://127.0.0.1:8000/login/?a1&b%221243%22 &#xff08;2&#xff09;post请求 在html使用post,login.html <!DOCTYPE html> <html lang"en&…

文献阅读:tidyomics 生态系统:增强组学数据分析

文献介绍 文献题目&#xff1a; The tidyomics ecosystem: enhancing omic data analyses 研究团队&#xff1a; Stefano Mangiola&#xff08;澳大利亚沃尔特和伊丽莎霍尔医学研究所&#xff09;、Michael I. Love&#xff08;美国北卡罗来纳大学教堂山分校&#xff09;、Ant…