[mermaid]graph TD
    A[Start: Two Pointer]
    A1[题号: 101, 102, 103]
    B[Search]
    B1[Binary Search]
    B1a[题号: 301, 302, 303]
    B2[DFS - Depth First Search]
    B2a[题号: 501, 502, 503]
    B3[BFS - Breadth First Search]
    B3a[题号: 601, 602, 603]
    C[Sort]
    C1[Bubble Sort]
    C1a[题号: 701, 702, 703]
    C2[Quick Sort]
    C2a[题号: 801, 802, 803]
    C3[Merge Sort]
    C3a[题号: 901, 902, 903]
    D[Greedy Algorithm]
    D1[题号: 1001, 1002, 1003]
    E[Divide and Conquer]
    E1[题号: 1101, 1102, 1103]
    F[DP - Dynamic Programming]
    F1[题号: 1201, 1202, 1203]

    A --> A1
    A --> B
    B --> B1
    B1 --> B1a
    B --> B2
    B2 --> B2a
    B --> B3
    B3 --> B3a
    B --> C
    C --> C1
    C1 --> C1a
    C --> C2
    C2 --> C2a
    C --> C3
    C3 --> C3a
    C --> D
    D --> D1
    D --> E
    E --> E1
    E --> F
    F --> F1 [/mermaid]

双指针

题号: 167 Two Sum II – Input Array Is Sorted

https://leetcode.com/problems/two-sum-ii-input-array-is-sorted/description/

题目描述

给定一个已按非递减顺序排列的整数数组numbers,请找出两个数,使它们相加之和等于特定目标数target。返回这两个数的索引(以1为起始索引),即numbers[index1]numbers[index2],其中1 <= index1 < index2 <= numbers.length

返回两个数字的索引,以长度为2的整数数组[index1, index2]的形式。测试用例保证有且仅有一个解决方案。不得使用相同元素两次。

您的解决方案只能使用恒定的额外空间。

我的要点笔记:

  1. 返还array 的语法是这样: return new int[] {l+1,r+1};,返还空array记得用new int [2].
  2. index要加1,因为他要的是第几位数而不是index

我的答案:

class Solution {
    public int[] twoSum(int[] numbers, int target) {
        int l = 0, r = numbers.length -1;
        while(l<r){
            int sum = numbers[l] + numbers[r];
            if(sum == target){
                return new int[] {l+1,r+1};
            }
            if( sum < target){
                l ++;
            }else{
                r--;
            }
        }
        return new int[2];
    }
}

更优答案:

(请在此处添加更优答案)


题号: 633 Sum of Square Numbers

https://leetcode.com/problems/sum-of-square-numbers/description/

题目描述

判断一个非负整数c是否为两个整数的平方和。换言之,是否存在两个整数ab,使得a^2 + b^2 = c

我的要点笔记:

  1. 使用Math.sqrt(target)作为初始r
  2. 因为涉及平方,使用long而不是int

我的答案:

class Solution {
    public boolean judgeSquareSum(int c) {
        long x =0, y = (long) Math.sqrt(c);
        while ( x <= y){
            long sum =x*x+y*y;
            if ( sum == c) return true;
            if (sum < c){
                x++;
            }else{
                y--;
            }
        }
        return false;
    }
}

更优答案:

(请在此处添加更优答案)


题号: 345 Reverse Vowels of a String

https://leetcode.com/problems/reverse-vowels-of-a-string/description/

题目描述

编写一个函数,以字符串作为输入,反转该字符串中的元音字母。

我的要点笔记:

  1. 用string或者hashset很快,储存vowels
  2. 可以用双while优化

我的答案:

class Solution {
    public String reverseVowels(String s) {
        String vowels = "AEIOUaeiou";
        int l = 0  , r = s.length()-1;
        char [] res = s.toCharArray();
        while(l < r){
            if(vowels.indexOf(s.charAt(l)) >= 0 &&vowels.indexOf(s.charAt(r)) >= 0){
                char temp = s.charAt(l);
                res[l] = res[r];
                res[r]=temp;
                l++;
                r--;
            }else if(vowels.indexOf(s.charAt(l)) < 0){
                l++;
            }else if(vowels.indexOf(s.charAt(r)) <0){
                r--;
            }
            
        }
        return new String(res);
    }
}

更优答案:

class Solution {
    public String reverseVowels(String s) {
        char[] word = s.toCharArray();
        int start = 0;
        int end = s.length() - 1;
        String vowels = "aeiouAEIOU";
        
        while (start < end) {
            // Move start pointer until it points to a vowel
            while (start < end && vowels.indexOf(word[start]) == -1) {
                start++;
            }
            
            // Move end pointer until it points to a vowel
            while (start < end && vowels.indexOf(word[end]) == -1) {
                end--;
            }
            
            // Swap the vowels
            char temp = word[start];
            word[start] = word[end];
            word[end] = temp;
            
            // Move the pointers towards each other
            start++;
            end--;
        }
        
        String answer = new String(word);
        return answer;
    }
}

题号: 680 Valid Palindrome II

https://leetcode.com/problems/valid-palindrome-ii/description/

题目描述

给定一个非空字符串s,最多删除一个字符。判断是否能成为回文字符串。

我的要点笔记:

  1. 我加了一个helper判断palindrome,然后一个boolean flag来判断是否可以移除一个字符
  2. 移除字符有两种情况,移除左边的或者右边的
  3. 大概是O(n)

我的答案:

class Solution {
    public boolean validPalindrome(String s) {
       return palindramHelper(s,true);

    }

    boolean palindramHelper(String s, boolean ifHasChance){
               int l = 0 , r = s.length()- 1;
       while( l <= r){
           if(s.charAt(l) == s.charAt(r)){
               l++;
               r--;
           }else{
                if(ifHasChance){
                    return palindramHelper(s.substring(l,r),false) || palindramHelper(s.substring(l+1,r+1),false);
                }else{
                    return false;
                }
           }
       } 
       return true;
    }
}

更优答案:

(请在此处添加更优答案)


题号: 88 Merge Sorted Array

https://leetcode.com/problems/merge-sorted-array/description/

题目描述

给你两个有序整数数组nums1nums2,请你将nums2合并到nums1中,使nums1成为一个有序数组。

初始化nums1nums2的元素数量分别为mn。你可以假设nums1有足够的空间(空间大小等于m + n)来保存nums2中的元素。

我的要点笔记:

  1. 从大到小排序
  2. 如果短的用尽了,可以判断退出因为肯定整个是sorted

我的答案:

class Solution {
    public void merge(int[] nums1, int m, int[] nums2, int n) {
        int x  = m-1, y = n - 1 , i = m+n-1;
        while(y >= 0){
            if(x >=0 && nums1[x] > nums2[y]){
                nums1[i] = nums1[x];
                x--;
            }else{
                nums1[i] = nums2[y];
                y--;
            }
            i--;
        }
    }
}

更优答案:

(请在此处添加更优答案)


题号: 141 Linked List Cycle

https://leetcode.com/problems/linked-list-cycle/description/

题目描述

给定一个链表,判断链表中是否有环。

为了表示给定链表中的环,我们使用整数pos来表示链表尾连接到链表中的位置(索引从0开始)。如果pos是-1,则在该链表中没有环。注意:pos不作为参数进行传递,仅仅是为了标识链表的实际情况。

如果链表中存在环,则返回true。否则,返回false

我的要点笔记:

  1. 差速,一个快一个慢,注意查null

我的答案:

/**
 * Definition for singly-linked list.
 * class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) {
 *         val = x;
 *         next = null;
 *     }
 * }
 */
public class Solution {
    public boolean hasCycle(ListNode head) {
        if( head == null)return false;
        ListNode list1= head;
        ListNode list2 =head.next;
        while ( list1 != null && list2 != null &&list1.next != null && list2.next!= null){
            if( list1==list2)return true;
            list1=list1.next;
            list2=list2.next == null? null : list2.next.next;
        }
        return false;
    }
}

更优答案:

/**
 * Definition for singly-linked list.
 * class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) {
 *         val = x;
 *         next = null;
 *     }
 * }
 */
public class Solution {
    public boolean hasCycle(ListNode head) {
        
        ListNode slow ,fast;
                if( head==null) return false;
        
        slow=head;
        fast=head.next;
        

        
        while(slow!=fast)  {
            
            if(fast==null || fast.next==null) return false;
            
            slow=slow.next;
            fast=fast.next.next;
        
            }
        
              return true;
     
        
    }
}

题号: 524 Longest Word in Dictionary through Deleting

https://leetcode.com/problems/longest-word-in-dictionary-through-deleting/description/

题目描述

给定一个字符串s和一个字符串数组d。你需要从s中删除一些字符,使得它构成字符串列表d中的一个字符串,找出能构成的最长字符串。如果有多个相同长度的结果,返回字典序中最小的字符串。

通过删除s中的一个字符能得到字符串t,可以认为ts的子序列,我们可以使用双指针来判断一个字符串是否为另一个字符串的子序列。

我的要点笔记:

  1. string对比大小用 curr.compareTo(res)
  2. 直接跳过不符合条件的string,比如过短

我的答案:

class Solution {
    public String findLongestWord(String s, List<String> dictionary) {
        String res = "";
        for(int i = 0 ; i < dictionary.size();  i++){
            String curr = dictionary.get(i);
            if(curr.length() < res.length()) continue;
            int l = 0 , r = 0;
            while (l < s.length() && r < curr.length()){
                if(s.charAt(l) == curr.charAt(r)){
                    r++;
                }
                l++;
            }
            if(r < curr.length())continue;
            if((curr.length() > res.length())||(res.length() == curr.length() &&  curr.compareTo(res) < 0)){
                res = curr;
            }
        }
        return res;
    }
}

更优答案:

(请在此处添加更优答案)


请根据您的需要在各部分填写相应的笔记和答案。如果您需要其他题目的信息,或有其他问题,随时告诉我!

Leave a Comment

Your email address will not be published. Required fields are marked *

Share the Post:

Related Posts

Barry 2024 总结

2024 是对我很有意义的一年,我换了工作,有弟兄和长辈的陪伴,有成长,有人际关系的反思,有去读书和与人建立关系,探索我想要的未来。 真的非常感恩身边的人,我所拥有的一切。 我觉得时间流逝不可怕,转眼快27了,可能很快就会30,简直不可思议。如果时间过去了自己没有改变,我会觉得很不值得。去年我的flag是比之前更会爱人,我觉得我满意自己的成长,爱远比我以为的要复杂和困难。但是事情的本质就是这样,认清本质而有方向的努力其实会更加心安。 我想对我自己说:你很棒,需要做的事情请去做,否则会后悔。不要担心身边没有支持者,我对你的认识是,你就是应该做提出改变和突破的事情,因为你内心不甘平淡,你也不能忍受无动于衷,你无法躲避内心和感动。知道对的事情,有能力去做而不去做,你做不到。蜘蛛侠里的Uncle Ben说过:Great power comes great responsibility,能力越大责任越大。 我做了很多新的尝试,从Visa裸辞,建立人际关系,参加营会感受神的改变,自己旅游。书本上乃至圣经上的道理,需要更多的人生经历加上反思感悟,才能淬炼出属于自己对爱和人的认识。去经历吧,趁着年轻;思考吧,趁着还对答案有渴望。 你有时候做事过于谨慎,不要太过于害怕去拥抱错了一个人。我很喜欢《死了都要爱》里的歌词: 别一开怀就怕受伤害——《死了都要爱》 你的生命不是关乎你自己,你不是你生命的中心。不要太过于self pity 自怜自爱,遇到不满意的现在就去思考如何改变吧,去探索和感受,不要拖延。你真正的观众很少,坚持自己认为对的事情。 2025 神为我预备了怎样的爱和挑战呢?

Read More

探索约翰福音与耶稣的兄弟:历史与神学的洞察

约翰门徒的争论:洗礼的意义 在约翰福音3:26中,我们读到施洗约翰的门徒与一位犹太人就洁净礼的问题展开辩论。这段记载引发了我们对讨论内容的推测和思考,可能包括: 约翰的回应:使命与焦点 施洗约翰在回应门徒时明确了自己的角色与使命,他强调:“他必兴旺,我必衰微”(约3:30)。这一有力的声明教导我们: 现代应用 今天,我们也面临类似的挑战:我们是否将焦点放在事工本身,而非耶稣?约翰的回应提醒我们,所有事工的目标应是彰显耶稣,而非提升个人声望。 约翰福音的独特风格与神学深度 约翰福音3:31-36展示了与其他福音书不同的叙述方式。这段经文并非出自耶稣或施洗约翰的直接发言,而是福音书作者插入的一段神学反思。 主要特点 风格原因 约翰经常在叙述中穿插神学洞见,以提供更深刻的理解。这种方式旨在: 这一风格与其他福音书主要记录耶稣言行的方式形成对比,突出了约翰福音独特的神学深度。 耶稣的兄弟:历史与经文背景 圣经提到耶稣的兄弟姐妹,特别是: 耶稣兄弟的名字 耶稣兄弟的贡献 这些经文提醒我们,耶稣的家庭成员在早期教会中扮演了重要角色,为我们提供了宝贵的属灵教导。 天主教对玛利亚与耶稣兄弟的看法 天主教认为,玛利亚终身童贞,并将“耶稣的兄弟”解释为: 新教的观点

Read More

Join Our Newsletter