leetcode刷题记录1-5

1. 两数之和
给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标。
你可以假设每种输入只会对应一个答案。但是,你不能重复利用这个数组中同样的元素。

示例:
给定 nums = [2, 7, 11, 15], target = 9
因为 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/two-sum

暴力破解法:
(用时长,消耗内存少)

	public int[] twoSum(int[] nums, int target) {
        for(int i=0;i<nums.length;i++){
            for(int j=0;j<nums.length;j++){
                if(i!=j&&target-nums[i]==nums[j])
                    return new int [] {i,j};
            }
        }
        return null;
    }

哈希表法:
(用时短,消耗内存多,以空间换时间)

	public int[] twoSum(int[] nums, int target) {
        Map<Integer,Integer> map=new HashMap<>();
        for(int i=0;i<nums.length;i++){
            int y=target-nums[i];
            if(map.containsKey(y)){
                return new int[] {map.get(y),i};
            }            
            map.put(nums[i],i);
        }
        return null;
    }

2. 两数相加
给出两个 非空 的链表用来表示两个非负的整数。其中,它们各自的位数是按照 逆序 的方式存储的,并且它们的每个节点只能存储 一位 数字。
如果,我们将这两个数相加起来,则会返回一个新的链表来表示它们的和。
您可以假设除了数字 0 之外,这两个数都不会以 0 开头。

示例:
输入:(2 -> 4 -> 3) + (5 -> 6 -> 4)
输出:7 -> 0 -> 8
原因:342 + 465 = 807
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/add-two-numbers

这里我被示例误导了好几次,事实上这两个链表的长度并不固定,而且可能很长。我根据示例试图使用val * 1+val * 10+val * 100…的方式进行计算,然而提交执行时的数据长达13个节点,直接导致了int数据溢出。
最终解题代码:

	public ListNode addTwoNumbers(ListNode l1, ListNode l2) {
        int count=0,carry=0,sum;
        ListNode ret=new ListNode(0),r=ret;
        while(l1!=null||l2!=null){
           if(l1!=null){
               count+=l1.val;
               l1=l1.next;
           }
           if(l2!=null){
               count+=l2.val;
               l2=l2.next;
           }
           sum=count+carry;
           r.next=new ListNode(sum%10);
           r=r.next;
           carry=sum/10;
           count=0;
        }
        if(carry!=0){
             r.next=new ListNode(1);
        }
        return ret.next;
    }

3. 无重复字符的最长子串
给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。

示例 1:
输入: “abcabcbb”
输出: 3
解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。
示例 2:
输入: “bbbbb”
输出: 1
解释: 因为无重复字符的最长子串是 “b”,所以其长度为 1。
示例 3:
输入: “pwwkew”
输出: 3
解释: 因为无重复字符的最长子串是 “wke”,所以其长度为 3。
请注意,你的答案必须是 子串 的长度,“pwke” 是一个子序列,不是子串。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/longest-substring-without-repeating-characters

这里注意题目给的字符串将 " 也算作了内容,例如"a"字符串长度为3,所以字符串的s.charAt(0) == s.charAt(s.length()-1)必然成立,不需要担心字符串从头到尾没有重复字符导致没有赋值的情况。
输入字符串可能出现为""" ",但因为"为字符串内容,对代码没有影响。
消耗时间,节省空间的方法:

	public int lengthOfLongestSubstring(String s) {
        System.out.println(s);
        int maxcount=0,maxcountin,len=s.length();
        for(int x=0;x<len;x++){
            maxcountin=len-x;
            for(int i=x;i<len;i++){
                for(int j=(i+1);j<x+maxcountin;j++){
                    if(s.charAt(i)==s.charAt(j)){
                        if(maxcountin>(j-x)){            
                            maxcountin=j-x;
                        }
                        break;
                    }
                }
            }
            if(maxcount<maxcountin){
                maxcount=maxcountin;
            }
        }
        return maxcount;
    }

4. 寻找两个有序数组的中位数

给定两个大小为 m 和 n 的有序数组 nums1 和 nums2。
请你找出这两个有序数组的中位数,并且要求算法的时间复杂度为 O(log(m + n))。
你可以假设 nums1 和 nums2 不会同时为空。

示例 1:
nums1 = [1, 3]
nums2 = [2]
则中位数是 2.0
示例 2:
nums1 = [1, 2]
nums2= [3, 4]
则中位数是 (2 + 3)/2 = 2.5

需要注意当其中一个数组归并完毕后可能出现的数组越界问题,以及总数为偶数时中位数取平均数的除法自动抹去小数点后数字问题(将/2改为/2.0)
解题代码:

public double findMedianSortedArrays(int[] nums1, int[] nums2) {
        int i=0,j=0,k=0,length=nums1.length+nums2.length;
        int nums[]=new int[length];
        for(;i<length;i++){
            if(nums1.length==j||nums2.length==k){
               break;
           }
            if(nums1[j]<nums2[k]){
                nums[i]=nums1[j];
                j++;
            }else{
                nums[i]=nums2[k];
                k++;
            }
        }
        while(j<nums1.length){
            nums[i++]=nums1[j];
            j++;
        }
        while(k<nums2.length){
            nums[i++]=nums2[k];
            k++;
        }
        if(length%2!=0){
            return nums[length/2];
        }else{
            return (nums[length/2-1]+nums[length/2])/2.0;
        }
    }

5. 最长回文子串
给定一个字符串 s,找到 s 中最长的回文子串。你可以假设 s 的最大长度为 1000。

示例 1:
输入: “babad”
输出: “bab”
注意: “aba” 也是一个有效答案。
示例 2:
输入: “cbbd”
输出:“bb”

我使用了将每一个字符视为可能的回文中点,向两边验证的方法,为了解决回文长度为偶数,即“abba”类型的回文,将字符串的每个字符之间插入了“#”字符,思路可行,但代码的执行用时和内存消耗都不算理想。
解题代码:

public String longestPalindrome(String s) {
        int site=0,length=0;
        StringBuffer b=new StringBuffer("#");
        for(int i=0;i<s.length();i++){
            b.append(s.charAt(i)+"#");
        }
        for(int i=1;i<b.length();i++){//size
           for(int j=1;j<b.length()-i;j++){//length
				if(i-j<0){
					break;
				}
				if(b.charAt(i-j)==b.charAt(i+j)){
					if(j>length) {
						site = i;
						length = j ;
					}
				}else {
					break;
				}
			}
        }
        StringBuffer b1=new StringBuffer();
        for(int i=0-length;i<=length;i++){
			if(b.charAt(i+site)!='#'){
				b1.append(b.charAt(i+site));
			}
		}
        return b1.toString();
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值