数据结构与算法
amwpjm
这个作者很懒,什么都没留下…
展开
专栏收录文章
- 默认排序
- 最新发布
- 最早发布
- 最多阅读
- 最少阅读
-
有效括号isValid
给定一个只包括 ‘(’,’)’,’{’,’}’,’[’,’]’ 的字符串,判断字符串是否有效。有效字符串需满足:左括号必须用相同类型的右括号闭合。 左括号必须以正确的顺序闭合。 注意空字符串可被认为是有效字符串。示例 1:输入: “()” 输出: true 示例 2:输入: “()[]{}” 输出: true 示例 3:输入: “(]” 输出: false 示例 4:输入: “([)]” 输出: false 示例 5:输入: “{[]}” 输出: truepackage com.M..原创 2020-05-30 19:36:05 · 300 阅读 · 0 评论 -
最长公共前缀longestCommonPrefix
编写一个函数来查找字符串数组中的最长公共前缀。如果不存在公共前缀,返回空字符串 “”。public class Solution { public String longestCommonPrefix(String [] strs){ //字符数组长度为0返回空 if (strs.length==0){ return ""; } //将第一个字符串取出来与.原创 2020-05-28 17:24:20 · 184 阅读 · 0 评论 -
罗马数字转换整数
罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。字符 数值 I 1 V 5 X 10 L50 C 100 D 500 M 1000 例如, 罗马数字 2写做 II ,即为两个并列的 1。12 写做 XII ,即为 X + II 。 27 写做 XXVII, 即为 XX + V + II 。通常情况下,罗马数字中小的数字.原创 2020-05-20 10:27:57 · 299 阅读 · 0 评论 -
回文数(palindrome number)
判断一个整数是否是回文数。回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。 输入: 121 输出: true输入: -121 输出: false输入: 10 输出: false 解释: 从右向左读, 为 01 。因此它不是一个回文数。普通数学方法public class Solution { public boolean isPalindrome(int x){ int a=0; int y=x; while (y!=0){ .原创 2020-05-19 21:32:33 · 681 阅读 · 0 评论 -
整数反转(reverse)
1.数学方法:·没有数组和堆栈的帮助下使用数学方法:从ans * 10 + pop > MAX_VALUE这个溢出条件来看·当出现 ans > MAX_VALUE / 10 且 还有pop需要添加 时,则一定溢出·当出现 ans == MAX_VALUE / 10 且 pop > 7 时,则一定溢出,7是2^31 - 1的个位数从ans * 10 + pop < MIN_VALUE这个溢出条件来看·当出现 ans < MIN_VALUE / 10 且 还有pop需要原创 2020-05-13 19:23:29 · 460 阅读 · 0 评论 -
每日一题(addTwoNumbers)
题目:给定两个非空链表来代表两个非负整数。数字最高位位于链表开始位置。它们的每个节点只存储单个数字。将这两数相加会返回一个新的链表。你可以假设除了数字 0 之外,这两个数字都不会以零开头。package com.May.addTwoNumbers;class ListNode{ int val; ListNode next; //下一个链表对象 ListNode(int x){val=x;}//赋给链表的值}public class Solution {原创 2020-05-12 17:37:11 · 281 阅读 · 0 评论 -
两数相加(twoSum)
01towsumpackage com.May.tosum;public class Solution { public int [] twosum(int sums[],int target){ for (int i=0;i<sums.length;i++){ for (int j=i+1;j<sums.length;j++){ if (target==sums[i]+sums[j]){原创 2020-05-11 20:51:14 · 177 阅读 · 0 评论 -
搜索插入位置
给定一个排序数组和一个目标值,在数组中找到目标值,并返回其索引。如果目标值不存在于数组中,返回它将会被按顺序插入的位置。你可以假设数组中无重复元素。示例 1:输入: [1,3,5,6], 5 输出: 2示例 2:输入: [1,3,5,6], 2 输出: 1二分法 时间复杂度O(logN)时间复杂度:O(logn),其中 n为数组的长度。二分查找所需的时间复杂度为 O(logn)。空间复杂度:O(1)。我们只需要常数空间存放若干变量。class Solution { publ原创 2020-10-15 12:41:36 · 117 阅读 · 0 评论 -
移出元素
给你一个数组 nums 和一个值 val,你需要 原地 移除所有数值等于 val 的元素,并返回移除后数组的新长度。不要使用额外的数组空间,你必须仅使用 O(1) 额外空间并 原地 修改输入数组。元素的顺序可以改变。你不需要考虑数组中超出新长度后面的元素。示例 1:给定 nums = [3,2,2,3], val = 3,函数应该返回新的长度 2, 并且 nums 中的前两个元素均为 2。你不需要考虑数组中超出新长度后面的元素。class Solution { public int原创 2020-10-15 10:48:27 · 227 阅读 · 0 评论 -
删除排序数组中的重复项
题目要求:给定一个排序数组,你需要在 原地 删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。 不要使用额外的数组空间,你必须在原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。给定数组 nums = [1,1,2],函数应该返回新的长度 2, 并且原数组 nums 的前两个元素被修改为 1, 2。你不需要考虑数组中超出新长度后面的元素。解法:双指针法public int removeDuplicates(int[] nums) { if (nums.原创 2020-10-14 12:58:53 · 166 阅读 · 0 评论
分享