算法| ss 字符串数组对象

2024-04-06 04:12

本文主要是介绍算法| ss 字符串数组对象,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

    1. 罗马数字转整数
  • 409.最长回文串
    1. 字符串相加
  • 594.最长和谐子序列

13. 罗马数字转整数

/*** @param {string} s* @return {number}*/
// 构建map匹配值,增加带IV这种的
// for遍历循环,
// 1.先看匹配是否满足2个字符的 i+2
// 2. 单个字符匹配
var romanToInt = function (s) {const map = {I: 1,IV: 4,V: 5,IX: 9,X: 10,XL: 40,L: 50,XC: 90,C: 100,CD: 400,D: 500,CM: 900,M: 1000,};let ans = 0;for (let i = 0; i < s.length; i++) {const substr = s.substring(i, i + 2);if (i + 1 < s.length && map[substr]) {ans += map[substr];i += 1;} else {ans += map[s[i]];}}//   console.log(ans);return ans;
};
// romanToInt("III");
// romanToInt("IV");
romanToInt("MCMXCIV");
// 示例 1:
// 输入: s = "III"
// 输出: 3
// 示例 2:
// 输入: s = "IV"
// 输出: 4

409.最长回文串

/*** @param {string} s* @return {number}*/
// 思路
// 统计各个字符出现的次数
// 统计奇数个数, 只留一个奇数个数,其他个数删除1
// 如果奇数个数大于1
// 总长度= 字符串长度- (奇数个数-1)
//
var longestPalindrome = function (s) {const map = {};for (let ch of s) {map[ch] = (map[ch] ?? 0) + 1;}let deleteCount = 0;for (let key in map) {if (map[key] % 2 !== 0) {deleteCount += 1;}}const ans = deleteCount > 1 ? s.length - (deleteCount - 1) : s.length;//   console.log(ans);return ans;
};
longestPalindrome("abccccdd");// 输入:s = "abccccdd"
// 输出:7

415. 字符串相加

/*** @param {string} num1* @param {string} num2* @return {string}*/
// 思路
// 从两个数的末尾进行取值 相加
// while循环很重要, i>=0 j>=0  carry>=0
// 往数组里添加 求余值放入数组  进位值进入下一轮计算
var addStrings = function (num1, num2) {let i = num1.length - 1;let j = num2.length - 1;let carry = 0;const res = [];while (i >= 0 || j >= 0 || carry !== 0) {let c1 = i >= 0 ? num1.charAt(i) - "0" : 0;let c2 = j >= 0 ? num2.charAt(j) - "0" : 0;// console.log("c1", c1);// console.log("c2", c2);const sum = c1 + c2 + carry;res.push(sum % 10);carry = Math.floor(sum / 10);i--;j--;}//   console.log(res);return res.reverse().join("");
};
addStrings("11", "123");
// 输入:num1 = "11", num2 = "123"
// 输出:"134"

594.最长和谐子序列

/*** @param {number[]} nums* @return {number}*/
// 思路
// 统计各个数出现的次数
// 利用map 来获取最大值
// map是有序的, 不想对象是无序的
var findLHS = function (nums) {const map = new Map();for (let ch of nums) {map.set(ch, (map.get(ch) ?? 0) + 1);}console.log(map);let max = 0;for (let key of map.keys()) {if (map.get(key + 1)) {max = Math.max(max, map.get(key) + map.get(key + 1));}}console.log(max);return max;
};
findLHS([1, 3, 2, 2, 5, 2, 3, 7]);
// 输入:nums = [1,3,2,2,5,2,3,7]
// 输出:5

这篇关于算法| ss 字符串数组对象的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/878968

相关文章

MySQL常用字符串函数示例和场景介绍

《MySQL常用字符串函数示例和场景介绍》MySQL提供了丰富的字符串函数帮助我们高效地对字符串进行处理、转换和分析,本文我将全面且深入地介绍MySQL常用的字符串函数,并结合具体示例和场景,帮你熟练... 目录一、字符串函数概述1.1 字符串函数的作用1.2 字符串函数分类二、字符串长度与统计函数2.1

C# $字符串插值的使用

《C#$字符串插值的使用》本文介绍了C#中的字符串插值功能,详细介绍了使用$符号的实现方式,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录$ 字符使用方式创建内插字符串包含不同的数据类型控制内插表达式的格式控制内插表达式的对齐方式内插表达式中使用转义序列内插表达式中使用

详解MySQL中JSON数据类型用法及与传统JSON字符串对比

《详解MySQL中JSON数据类型用法及与传统JSON字符串对比》MySQL从5.7版本开始引入了JSON数据类型,专门用于存储JSON格式的数据,本文将为大家简单介绍一下MySQL中JSON数据类型... 目录前言基本用法jsON数据类型 vs 传统JSON字符串1. 存储方式2. 查询方式对比3. 索引

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

Python中反转字符串的常见方法小结

《Python中反转字符串的常见方法小结》在Python中,字符串对象没有内置的反转方法,然而,在实际开发中,我们经常会遇到需要反转字符串的场景,比如处理回文字符串、文本加密等,因此,掌握如何在Pyt... 目录python中反转字符串的方法技术背景实现步骤1. 使用切片2. 使用 reversed() 函

Python实现对阿里云OSS对象存储的操作详解

《Python实现对阿里云OSS对象存储的操作详解》这篇文章主要为大家详细介绍了Python实现对阿里云OSS对象存储的操作相关知识,包括连接,上传,下载,列举等功能,感兴趣的小伙伴可以了解下... 目录一、直接使用代码二、详细使用1. 环境准备2. 初始化配置3. bucket配置创建4. 文件上传到os

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.