1. 两数之和

var twoSum = function(nums, target) {
// 第一种
// var len = nums.length
// for (var i = 0; i < len; i++) {
// for (var j = i + 1; j < len; j++) {
// if (target - nums[i] == nums[j]) {
// return [i, j]
// }
// }
// }
// 第二种
var map = new Map()
for (let i = 0; i < nums.length; i++) {
var comNum = target - nums[i]
if (map.has(comNum)) {
return [map.get(comNum), i]
} else {
map.set(nums[i], i)
}
}
return []
};

9. 回文数

var isPalindrome = function(x) {
var str = '' + x
var left = 0
var right = str.length - 1
while (left < right) {
if (str.charAt(left) != str.charAt(right)) {
return false
}
left++
right--
}
return true
};

13. 罗马数字转整数

var romanToInt = function(s) {
var roman = ['I', 'V', 'X', 'L', 'C', 'D', 'M', 'IV', 'IX', 'XL', 'XC', 'CD', 'CM']
var num = [1, 5, 10, 50, 100, 500, 1000, 4, 9, 40, 90, 400, 900]
var res = 0
for (var i = 0; i < s.length; i++) {
var t = s[i] + s[i + 1]
if (roman.indexOf(t) >= 0) {
res += num[roman.indexOf(t)]
i++
} else {
res += num[roman.indexOf(s[i])]
}
}
return res
};

14. 最长公共前缀

var longestCommonPrefix = function(strs) {
var res = ''
if (strs.length == 0) {
return res
}
for (var i = 0; i < strs[0].length; i++) {
for (var j = 0; j < strs.length; j++) {
if (strs[0][i] != '' && strs[0][i] != strs[j][i]) {
return res
}
}
res += strs[0][i]
}
return res
};

20. 有效的括号

var isValid = function(s) {
if (s.length % 2 !== 0) return false
let tmp = ['(', '[', '{', ')', ']', '}'] // 012345
let result = []
for (let i = 0; i < s.length; i++) {
if (tmp.indexOf(s[i]) <= 2) {
result.push(s[i])
} else {
let last = result.pop()
if (tmp.indexOf(last) + 3 != tmp.indexOf(s[i])) {
return false
}
}
}
if (result.length > 0) return false
return true
};

21. 合并两个有序链表

var mergeTwoLists = function(l1, l2) {
let prevhead = new ListNode(-1)
let prev = prevhead
while (l1 !== null && l2 !== null) {
if (l1.val <= l2.val) {
prev.next = l1
l1 = l1.next
} else {
prev.next = l2
l2 = l2.next
}
prev = prev.next
}
prev.next = l1 === null ? l2 : l1 return prevhead.next
};

26. 删除有序数组中的重复项

var removeDuplicates = function(nums) {
for (var i = 0; i < nums.length; i++) {
if (nums[i] == nums[i + 1]) {
nums.splice(i, 1);
i--
}
}
return nums.length
};

27. 移除元素

var removeElement = function(nums, val) {
for (let i = 0; i < nums.length; i++) {
if (nums[i] == val) {
nums.splice(i, 1);
i--;
}
}
return nums.length
};

35. 搜索插入位置

var searchInsert = function(nums, target) {
var min = 0;
var max = nums.length - 1;
if (target < nums[min]) return min;
if (target > nums[max]) return max + 1;
while (min <= max) {
var mid = parseInt((min + max) / 2)
if (target == nums[mid]) {
return mid
} else if (target > nums[mid]) {
min = mid + 1
} else {
max = mid - 1
}
}
return min
};

58. 最后一个单词的长度

var lengthOfLastWord = function(s) {
s = s.trim().replace(/\s+/g, ' ')
var arr = s.split(' ')
return arr[arr.length - 1].length
};

leetcode简单(数组,字符串,链表):[1, 9, 13, 14, 20, 21, 26, 27, 35, 58]的更多相关文章

  1. redis底层数据结构--简单动态字符串 链表 字典 跳跃表 整数集合 压缩列表

    1.动态字符串 redis中使用c语言的字符床存储字面量,默认字符串存储采用自己构建的简单动态字符串SDS(symple dynamic string) redis包含字符串的键值对都是用SDS实现的 ...

  2. 【redis】redis底层数据结构原理--简单动态字符串 链表 字典 跳跃表 整数集合 压缩列表等

    redis有五种数据类型string.list.hash.set.zset(字符串.哈希.列表.集合.有序集合)并且自实现了简单动态字符串.双端链表.字典.压缩列表.整数集合.跳跃表等数据结构.red ...

  3. LeetCode 简单 -旋转字符串(796)

    给定两个字符串, A 和 B. A 的旋转操作就是将 A 最左边的字符移动到最右边. 例如, 若 A = 'abcde',在移动一次之后结果就是'bcdea' .如果在若干次旋转操作之后,A 能变成B ...

  4. redis 笔记01 简单动态字符串、链表、字典、跳跃表、整数集合、压缩列表

    文中内容摘自<redis设计与实现> 简单动态字符串 1. Redis只会使用C字符串作为字面量,在大多数情况下,Redis使用SDS(Simple Dynamic String,简单动态 ...

  5. 复杂的字符串数组解析:{"setting":"简单:10:5,一般:5:10,困难:2:20"},使用split多次截取

    "[0,{"id":563,"name":"测试题1","dscr":null,"picId&quo ...

  6. [Java]字符串数组 与 字符串链表 之间的相互转化

    代码: package com.hy; import java.util.Arrays; import java.util.Collections; import java.util.List; pu ...

  7. 【leetcode 206】 反转链表(简单)

    链表 概念: 区别于数组,链表中的元素不是存储在内存中连续的一片区域,链表中的数据存储在每一个称之为「结点」复合区域里,在每一个结点除了存储数据以外,还保存了到下一个结点的指针(Pointer). 由 ...

  8. C#LeetCode刷题-字符串

    字符串篇 # 题名 刷题 通过率 难度 3 无重复字符的最长子串   24.6% 中等 5 最长回文子串   22.4% 中等 6 Z字形变换   35.8% 中等 8 字符串转整数 (atoi)   ...

  9. Collection集合重难点梳理,增强for注意事项和三种遍历的应用场景,栈和队列特点,数组和链表特点,ArrayList源码解析, LinkedList-源码解析

    重难点梳理 使用到的新单词: 1.collection[kəˈlekʃn] 聚集 2.empty[ˈempti] 空的 3.clear[klɪə(r)] 清除 4.iterator 迭代器 学习目标: ...

  10. 11-C语言指针&一维数组&字符串

    一.用指针遍历数组元素 1.最普通的遍历方式是用数组下标来遍历元素 1 // 定义一个int类型的数组 2 int a[4] = {1, 2, 3, 4}; 3 4 int i; 5 for (i = ...

随机推荐

  1. 西门子PLC设备如何接入AIRIOT物联网低代码平台 ?

    西门子PLC设备广泛应用于工业控制领域,高性能和稳定是它最大的优势.下面我们要把西门子300 1200 1500 PLC设备连接到AIRIOT物联网低代码平台,具体操作如下所示: 西门子驱动配置(配套 ...

  2. 终于搞懂了!原来 Vue 3 的 generate 是这样生成 render 函数的

    前言 在之前的 面试官:来说说vue3是怎么处理内置的v-for.v-model等指令? 文章中讲了transform阶段处理完v-for.v-model等指令后,会生成一棵javascript AS ...

  3. Spring 对 Junit4,Junit5 的支持上的运用

    1. Spring 对 Junit4,Junit5 的支持上的运用 @ 目录 1. Spring 对 Junit4,Junit5 的支持上的运用 每博一文案 2. Spring对Junit4 的支持 ...

  4. 为什么不推荐在Spring Boot中使用@Value加载配置

    @Value注解相信很多Spring Boot的开发者都已经有接触了,通过使用该注解,我们可以快速的把配置信息加载到Spring的Bean中. 比如下面这样,就可以轻松的把配置文件中key为com.d ...

  5. 【ESP32】制作 Wi-fi 音箱(HTTP + I2S 协议)

    用 Wifi 来传输音频数据,会比蓝牙更好.使用蓝牙方式,不管你用什么协议,都会对数据重新编码,说人话就是有损音质,虽然不至于全损.而使用 Wifi 就可以将 PCM 数据直接传输,无需再编码和压缩. ...

  6. .NET Core应用程序每次启动后使用string.GetHashCode()方法获取到的哈希值(hash)不相同

    前言 如标题所述,在ASP.NET Core应用程序中,使用string.GetHashCode()方法去获取字符串的哈希值,但每次重启这个ASP.NET Core应用程序之后,同样的字符串的哈希值( ...

  7. 谁说爬虫只能Python?看我用C#快速简单实现爬虫开发和演示!

    前言:说到爬虫,基本上清一色的都知道用Python,但是对于一些没玩过或者不想玩Python的来说,却比较头大一点.所以以下我站在C# 的角度,来写一个简单的Demo,用来演示C# 实现的简单小爬虫. ...

  8. php分组查询和聚合函数 数据显示的顺序

      // 分组查询和聚合函数         // 分组查询 : 将指定字段中的数据,按照不同的具体数值,进行分组         //           数据相同的分在一个分组中          ...

  9. win10无线网卡不会自动连接

    usb接口的网卡.win10无线网卡不会自动连接. 解决方法: 第一步:在控制面板\网络和 Internet\网络连接中,禁用再启用一次无线网络. 第二步:在 控制面板\硬件和声音\电源选项\选择电源 ...

  10. OAuth + Security - 错误收集

    Could not decode JSON for additional information: BaseClientDetails 完整的错误输出如下: 2019-12-03 22:18:37.2 ...