Leetcode第382场周赛

Leetcode第382场周赛

在这里插入图片描述
在这里插入图片描述
本人水平有限,只做前三道。

一、按键变更的次数

给你一个下标从 0 开始的字符串 s ,该字符串由用户输入。按键变更的定义是:使用与上次使用的按键不同的键。例如 s = “ab” 表示按键变更一次,而 s = “bBBb” 不存在按键变更。

返回用户输入过程中按键变更的次数。

注意:shift 或 caps lock 等修饰键不计入按键变更,也就是说,如果用户先输入字母 ‘a’ 然后输入字母 ‘A’ ,不算作按键变更。

示例 1:

输入:s = “aAbBcC”
输出:2
解释:
从 s[0] = ‘a’ 到 s[1] = ‘A’,不存在按键变更,因为不计入 caps lock 或 shift 。
从 s[1] = ‘A’ 到 s[2] = ‘b’,按键变更。
从 s[2] = ‘b’ 到 s[3] = ‘B’,不存在按键变更,因为不计入 caps lock 或 shift 。
从 s[3] = ‘B’ 到 s[4] = ‘c’,按键变更。
从 s[4] = ‘c’ 到 s[5] = ‘C’,不存在按键变更,因为不计入 caps lock 或 shift 。
示例 2:

输入:s = “AaAaAaaA”
输出:0
解释: 不存在按键变更,因为这个过程中只按下字母 ‘a’ 和 ‘A’ ,不需要进行按键变更。

解题思路

每个字符都与其自身的上一个字符进行比较,如果不同,则计数+1

代码
public int countKeyChanges(String s) {
    int count = 0;
    char prevChar = '\0';

    for (int i = 0; i < s.length(); i++) {
        char currentChar = s.charAt(i);
        if(prevChar != '\0' && Character.toLowerCase(currentChar) != Character.toLowerCase(prevChar)){
            count++;
        }
        prevChar = s.charAt(i);
    }

    return count;
}
二、子集中元素的最大数量

给你一个 正整数 数组 nums 。

你需要从数组中选出一个满足下述条件的
子集

你可以将选中的元素放置在一个下标从 0 开始的数组中,并使其遵循以下模式:[x, x2, x4, …, xk/2, xk, xk/2, …, x4, x2, x](注意,k 可以是任何 非负 的 2 的幂)。例如,[2, 4, 16, 4, 2] 和 [3, 9, 3] 都符合这一模式,而 [2, 4, 8, 4, 2] 则不符合。
返回满足这些条件的子集中,元素数量的 最大值 。

示例 1:

输入:nums = [5,4,1,2,2]
输出:3
解释:选择子集 {4,2,2} ,将其放在数组 [2,4,2] 中,它遵循该模式,且 22 == 4 。因此答案是 3 。
示例 2:

输入:nums = [1,3,2,4]
输出:1
解释:选择子集 {1},将其放在数组 [1] 中,它遵循该模式。因此答案是 1 。注意我们也可以选择子集 {2} 、{4} 或 {3} ,可能存在多个子集都能得到相同的答案。

解题思路

1.使用TreeMap来统计数组nums中每个数字出现的次数。这个数据结构能够根据键值自动排序,方便后续处理。
2.通过枚举的方式,从最小的数字开始,检查每个数字能否作为序列的起点。找到起点之后,获取以其为起点的最大子集,并且对各个不同起点的最大子集长度取最大值,得到最终结果。
3.如何获取最大子集?
通过哈希表存储每个数字出现的次数,并且用num代表应该出现的数字,如果数字为波峰,那么该数字出现的次数为1;如果数字不是波峰,那么该数字出现的次数为2.
4.如果数组的长度为偶数,那么答案为最大长度-1;如果数组的长度为奇数,那么答案为最大长度

代码
public int maximumLength(int[] nums) {
     // 1.使用TreeMap统计各数字出现的次数,并利用特性对key从小到大排序
     TreeMap<Integer,Integer> numCntMap = new TreeMap<>();
     for(int num:nums){
         numCntMap.put(num, numCntMap.getOrDefault(num, 0)+1);
     }

     // 2.枚举,同时删除已访问的元素
     int maxCnt = 1;
     while(!numCntMap.isEmpty()){
         int tmpCnt = 0;
         Map.Entry<Integer,Integer> firstEntry = numCntMap.firstEntry();
         int num = firstEntry.getKey();
         if (num == 1){
             // 处理特例1
             maxCnt = Math.max(maxCnt,firstEntry.getValue()%2==0?firstEntry.getValue()-1:firstEntry.getValue());
             numCntMap.pollFirstEntry();
             continue;
         }
         while(numCntMap.containsKey(num)){
             int numCnt = numCntMap.get(num);
             numCntMap.remove(num,numCnt);
             // 判断数字出现的次数
             if(numCnt == 1){
                 // 波峰,结束枚举
                 tmpCnt++;
                 break;
             } else{
                 tmpCnt += 2;
                 num *= num;
             }
         }

         // 处理最后的峰值,峰值元素只取1个
         tmpCnt = tmpCnt % 2 == 0 ? tmpCnt - 1 : tmpCnt;
         maxCnt = Math.max(maxCnt,tmpCnt);
     }
     return maxCnt;
 }
三、Alice和Bob玩鲜花游戏
题目

Alice 和 Bob 在一个长满鲜花的环形草地玩一个回合制游戏。环形的草地上有一些鲜花,Alice 到 Bob 之间顺时针有 x 朵鲜花,逆时针有 y 朵鲜花。

游戏过程如下:

Alice 先行动。
每一次行动中,当前玩家必须选择顺时针或者逆时针,然后在这个方向上摘一朵鲜花。
一次行动结束后,如果所有鲜花都被摘完了,那么 当前 玩家抓住对手并赢得游戏的胜利。
给你两个整数 n 和 m ,你的任务是求出满足以下条件的所有 (x, y) 对:

按照上述规则,Alice 必须赢得游戏。
Alice 顺时针方向上的鲜花数目 x 必须在区间 [1,n] 之间。
Alice 逆时针方向上的鲜花数目 y 必须在区间 [1,m] 之间。
请你返回满足题目描述的数对 (x, y) 的数目。

示例 1:

输入:n = 3, m = 2
输出:3
解释:以下数对满足题目要求:(1,2) ,(3,2) ,(2,1) 。
示例 2:

输入:n = 1, m = 1
输出:0
解释:没有数对满足题目要求。

解题思路

由于Alice先行动,并且要求Alice赢,题目转化为:

  • 鲜花数量x+y是奇数
  • 顺时针方向的鲜花数量x满足1≤x≤n
  • 逆时针方向的鲜花数量y满足1≤y≤m
    由于x+y是奇数,因此xy的奇偶性不同,分类讨论。
    x是奇数且y是偶数时,x的取值个数是floor(n/2)y的取值个数是ceil(m/2)
    x是偶数且y是奇数时,x的取值个数是ceil(n/2)y的取值个数是floor(m/2)
    因此x+y等同于floor(n/2)ceil(m/2)+ceil(n/2)floor(m/2),等同于(n/2)((m+1)/2)+((n+1)/2)(m/2)
代码
public long flowerGame(int n, int m) {
    return (long) ((n + 1) / 2) * (m / 2) + (long) (n / 2) * ((m + 1) / 2);
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

机器学习:梯度下降法(Python)

LinearRegression_GD.py import numpy as np import matplotlib.pyplot as pltclass LinearRegression_GradDesc:"""线性回归&#xff0c;梯度下降法求解模型系数1、数据的预处理&#xff1a;是否训练偏置项fit_intercept&#xff08;默认True&#xff09;&…

【数据分享】1929-2023年全球站点的逐月最高气温数据(Shp\Excel\无需转发)

气象数据是在各项研究中都经常使用的数据&#xff0c;气象指标包括气温、风速、降水、湿度等指标&#xff0c;其中又以气温指标最为常用&#xff01;说到气温数据&#xff0c;最详细的气温数据是具体到气象监测站点的气温数据&#xff01; 之前我们分享过1929-2023年全球气象站…

C# Onnx yolov8 仪表指针检测

目录 效果 模型信息 项目 代码 训练数据 下载 C# Onnx yolov8 仪表指针检测 效果 模型信息 Model Properties ------------------------- date&#xff1a;2024-01-31T11:19:38.828556 author&#xff1a;Ultralytics task&#xff1a;detect license&#xff1a;AGPL-…

wordpress怎么做产品展示站?推荐使用MOK主题和ent主题

大多数WordPress站点都是个人博客网站&#xff0c;主要以文章性质的图文为主。不过部分站长想要用WordPress搭建一个产品展示站&#xff0c;应该怎么做呢&#xff1f; 其实&#xff0c;WordPress可以用来建立各种各样的博客网站&#xff0c;包括个人博客、企业网站、商城、影视…

小白级教程,10秒开服《幻兽帕鲁》

在帕鲁的世界&#xff0c;你可以选择与神奇的生物「帕鲁」一同享受悠闲的生活&#xff0c;也可以投身于与偷猎者进行生死搏斗的冒险。帕鲁可以进行战斗、繁殖、协助你做农活&#xff0c;也可以为你在工厂工作。你也可以将它们进行售卖&#xff0c;或肢解后食用。 前言 马上过年…

带大家详细了解msvcr120.dll丢失的原因,msvcr120.dll丢失怎样修复的方法

在使用电脑和运行应用程序时&#xff0c;我们经常会遇到与动态链接库&#xff08;Dynamic Link Library, DLL&#xff09;文件相关的错误。其中之一是 "msvcr120.dll 丢失" 的错误提示。今天我们就来详细的了解一下msvcr120.dll这个文件和分享msvcr120.dll丢失怎样修…

从宏观上对人工智能(AI)的一些理解

1.人工智能概述 68年前&#xff0c;约翰麦卡锡在“达特茅斯会议”正式提出人工智能概念。直到2023年&#xff0c;ChatGPT掀起全球AI大模型浪潮&#xff0c;英伟达市值一年飙涨2.4倍&#xff0c;真正意义上的“人工智能元年”到来了。 提到人工智能&#x…

事件驱动架构:使用Flask实现MinIO事件通知Webhooks

MinIO的事件通知可能一开始看起来并不激动人心&#xff0c;但一旦掌握了它们的力量&#xff0c;它们就能照亮您存储桶内的动态。事件通知是一个全面、高效的对象存储系统中的关键组件。Webhooks是我个人最喜欢的工具&#xff0c;用于与MinIO集成。它们在事件的世界中就像一把瑞…

八种Flink任务监控告警方式

目录 一、Flink应用分析 1.1 Flink任务生命周期 1.2 Flink应用告警视角分析 二、监控告警方案说明 2.1 监控消息队中间件消费者偏移量 2.2 通过调度系统监控Flink任务运行状态 2.3 引入开源服的SDK工具实现 2.4 调用FlinkRestApi实现任务监控告警 2.5 定时去查询目标库…

在深度学习中,epoch和learning rate的通常取值范围?

在深度学习中&#xff0c;epoch和学习率的取值确实会根据不同的任务、数据集和模型架构有所不同。然而&#xff0c;您提到的范围是一些常见的经验性取值&#xff0c;这些取值在很多情况下都能工作得相当好。 1. 对于epoch的取值范围&#xff1a; 在很多研究论文和实际应用中&…

机器学习 | 掌握逻辑回归在实践中的应用

目录 初识逻辑回归 逻辑回归实操 分类评估方法 初识逻辑回归 逻辑回归&#xff08;LogisticRegression&#xff09;是机器学习中的一种分类模型&#xff0c;逻辑回归是一种分类算法&#xff0c;虽然名字中带有回归&#xff0c;但是它与回归之间有一定的联系。由于算法的简单…

tui-datetime组件由弹窗显示改成页面直接展示

效果图 代码 <template><view class"tui-datetime-picker" :style"{zIndex}"><view class"tui-datetime__header" :class"{ tui-show: isShow }" :style"{zIndex:getPickerZIndex}"><view class&quo…

论文阅读-一个用于云计算中自我优化的通用工作负载预测框架,

论文标题&#xff1a;A Self-Optimized Generic Workload Prediction Framework for Cloud Computing 概述 准确地预测未来的工作负载&#xff0c;如作业到达率和用户请求率&#xff0c;对于云计算中的资源管理和弹性非常关键。然而&#xff0c;设计一个通用的工作负载预测器…

spring-boot-admin的介绍和使用

概述 Spring Boot 有一个非常好用的监控和管理的源软件&#xff0c;这个软件就是 Spring Boot Admin。该软件能够将 Actuator 中的信息进行界面化的展示&#xff0c;也可以监控所有 Spring Boot 应用的健康状况&#xff0c;提供实时警报功能。 主要的功能点有&#xff1a; 显…

springboot集成rocketmq-spring-boot-starter的坑(避坑指南)

1.说明版本&#xff08;解决方法&#xff09; springboot版本&#xff1a;2.2.2.RELEASE RocketMQ版本&#xff1a;rocketmq-spring-boot-starter 2.2.2 2.坑 rocketmq-spring-boot-starter的版本一开始&#xff0c;使用的是2.2.0版本&#xff0c;一直出现一个问题&#x…

leetcode刷题(剑指offer) 101.对称二叉树

101.对称二叉树 给你一个二叉树的根节点 root &#xff0c; 检查它是否轴对称。 示例 1&#xff1a; 输入&#xff1a;root [1,2,2,3,4,4,3] 输出&#xff1a;true示例 2&#xff1a; 输入&#xff1a;root [1,2,2,null,3,null,3] 输出&#xff1a;false提示&#xff1a; …

探究HMAC算法:消息认证与数据完整性的完美结合

Hash-based Message Authentication Code&#xff08;基于哈希的消息认证码&#xff0c;简称HMAC&#xff09;算法作为一种广泛应用的消息认证码&#xff08;MAC&#xff09;算法&#xff0c;在现代信息安全领域起着至关重要的作用。本文将从算法原理、优缺点、实际应用等方面&…

RS485自动收发电路震荡的问题

电路 设计初衷 电源5V 选择5V的原因&#xff0c;差分2.5V比1.5V可以提高传输能力 TTL输入 3.3V电平满足需求 TTL输出 4.5V了&#xff0c;MCU是3.3V平台 这样就分为两种情况 MCU接收端可以容忍5V输入 MCU接收端不可以容忍5V输入&#xff0c;就要进行电压转换&#xff0c;我这里使…

VS之调用程序对DLL中全局变量的使用

接上篇《VS生成C动态链接库DLL》&#xff0c;能够生成DLL&#xff0c;且能调用后&#xff0c;遇到一个问题&#xff0c;即在DLL程序中定义了一些全局变量&#xff0c;应用程序需要使用&#xff0c;本以为可以直接使用&#xff0c;没想到&#xff0c;还是需要设置才可以&#xf…

Zookeeper服务注册与发现实战

目录 设计思路 Zookeeper注册中心的优缺点 SpringCloudZookeeper实现微服务注册中心 第一步&#xff1a;在父pom文件中指定Spring Cloud版本 第二步&#xff1a;微服务pom文件中引入Spring Cloud Zookeeper注册中心依赖 第三步&#xff1a; 微服务配置文件application.y…
最新文章