亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

4th Feb 刷題筆記

2019-11-14 09:01:25
字體:
來源:轉載
供稿:網友

1、(206). Reverse Linked List

Reverse a singly linked list.

/** * Definition for singly-linked list. * public class ListNode { *     int val; *     ListNode next; *     ListNode(int x) { val = x; } * } */public class Solution {    public ListNode reverseList(ListNode head) {        if (head == null || head.next == null) {            return head;        }                ListNode cur = head;        ListNode PRev = null;        ListNode tmp = null;                while (cur != null) {            tmp = cur.next;            cur.next = prev;            prev = cur;            cur = tmp;        }                return prev;    }}

凡是涉及到交換,一般都要涉及到新建一個臨時的第三方變量。

2、( 445). Add Two Numbers II

You are given two non-empty linked lists representing two non-negative integers. The most significant digit comes first and each of their nodes contain a single digit. Add the two numbers and return it as a linked list.You may assume the two numbers do not contain any leading zero, except the number 0 itself.Follow up:What if you cannot modify the input lists? In other Words, reversing the lists is not allowed.Example:Input: (7 -> 2 -> 4 -> 3) + (5 -> 6 -> 4)Output: 7 -> 8 -> 0 -> 7

方法一:利用鏈表轉置和鏈表合并求和(鏈表合并的基礎上求和)

/** * Definition for singly-linked list. * public class ListNode { *     int val; *     ListNode next; *     ListNode(int x) { val = x; } * } */  /**  * Way 1: Use reverse LinkedList  */public class Solution {    private ListNode reverseLList(ListNode head) {        if (head == null || head.next == null) {            return head;        }                ListNode cur = head;        ListNode prev = null;        ListNode tmp = null;                while (cur != null) {            tmp = cur.next;            cur.next = prev;            prev = cur;            cur = tmp;        }        return prev;    }        private ListNode mergeSum(ListNode l1, ListNode l2) {        ListNode dummy = new ListNode(-1);        ListNode backup = dummy;        int overflow = 0;        int tmpSum = 0;                while (l1 != null && l2 != null) {            tmpSum = l1.val + l2.val + overflow;            if (tmpSum >= 10) {                overflow = 1;                tmpSum = tmpSum % 10;            } else {                overflow = 0;            }            dummy.next = new ListNode(tmpSum);            dummy = dummy.next;            l1 = l1.next;            l2 = l2.next;        }                while (l1 != null) {            tmpSum = l1.val + overflow;            if (tmpSum >= 10) {                overflow = 1;                tmpSum = tmpSum % 10;            } else {                overflow = 0;            }            dummy.next = new ListNode(tmpSum);            dummy = dummy.next;            l1 = l1.next;        }                while (l2 != null) {            tmpSum = l2.val + overflow;            if (tmpSum >= 10) {                overflow = 1;                tmpSum = tmpSum % 10;            } else {                overflow = 0;            }            dummy.next = new ListNode(tmpSum);            dummy = dummy.next;            l2 = l2.next;        }                if (overflow != 0) {//錯誤1            dummy.next = new ListNode(overflow);            dummy = dummy.next;        }                return backup.next;    }    public ListNode addTwoNumbers(ListNode l1, ListNode l2) {        ListNode headL1 = reverseLList(l1);        ListNode headL2 = reverseLList(l2);                ListNode ans = mergeSum(headL1, headL2);                ans = reverseLList(ans);                return ans;    }}

這題犯的錯誤在于:忘了考慮兩個相等位數的數相加要是有進位的時候,要把進位放進結果里。

方法二:不實際轉置鏈表,利用stack來實現轉置。寫這個程序時,犯了兩個錯誤:1) LinkedList實現stack的時候,注意如果直接使用removeLast()的方法時,當LinkedList為空,會直接返回NoSuchElement 的run time exception,而使用peekLast() 則只會返回空。另外,可以使用isEmpty()來檢查是否為空。2)StackReverse是為了產生一個新的鏈表,當你產生一個新的鏈表時,需要構建的每一個都要構造一個新的節點,不能連接到舊的節點。(Deep Copy那題也犯了這個錯誤)

/** * Definition for singly-linked list. * public class ListNode { *     int val; *     ListNode next; *     ListNode(int x) { val = x; } * } */public class Solution {    private ListNode stackReverse (ListNode head) {        LinkedList<ListNode> stack = new LinkedList<ListNode>();        ListNode dummy = new ListNode(-1);        ListNode backupDummy = dummy;        ListNode tmp = null;                //put all the listnode into the stack        while (head != null) {            stack.addLast(head);            head = head.next;        }                //pop all the listnode and construct a new linkedlist        while (!(stack.isEmpty())) {//注意補充下API的知識            tmp = stack.removeLast();            dummy.next = new ListNode(tmp.val);            dummy = dummy.next;        }                return backupDummy.next;    }        private ListNode mergeSum(ListNode l1, ListNode l2) {        int tmpSum = 0;        int overFlow = 0;                ListNode dummy = new ListNode(-1);        ListNode backupDummy = dummy;                while (l1 != null && l2 != null) {            tmpSum = l1.val + l2.val + overFlow;            if (tmpSum >= 10) {                overFlow = 1;                tmpSum = tmpSum % 10;            } else {                overFlow = 0;            }            dummy.next = new ListNode(tmpSum);            dummy = dummy.next;            l1 = l1.next;            l2 = l2.next;        }                while (l1 != null) {            tmpSum = l1.val + overFlow;            if (tmpSum >= 10) {                overFlow = 1;                tmpSum = tmpSum % 10;            } else {                overFlow = 0;            }            dummy.next = new ListNode(tmpSum);            dummy = dummy.next;            l1 = l1.next;        }                while (l2 != null) {            tmpSum = l2.val + overFlow;            if (tmpSum >= 10) {                overFlow = 1;                tmpSum = tmpSum % 10;            } else {                overFlow = 0;            }            dummy.next = new ListNode(tmpSum);            dummy = dummy.next;            l2 = l2.next;        }                //do not forget the overflow        if (overFlow != 0) {            dummy.next = new ListNode(overFlow);            overFlow = 0;            dummy = dummy.next;        }                return backupDummy.next;    }        public ListNode addTwoNumbers(ListNode l1, ListNode l2) {        ListNode newListOne = stackReverse(l1);        ListNode newListTwo = stackReverse(l2);                ListNode ans = mergeSum(newListOne, newListTwo);                ListNode answer = stackReverse(ans);                return answer;    }}

3/  (138.)Copy List with Random Pointer

A linked list is given such that each node contains an additional random pointer which could point to any node in the list or null.Return a deep copy of the list.

這道題有兩種方法,具體的可以參考刷題題庫1.這里作簡略描述:

方法一:使用hashtable,遍歷整個鏈表,把每個節點的新節點(注意不是random節點,這里想錯了)存在hashtable,同時創建一個沒有random pointer但其余一樣的鏈表。然后第二遍再通過hashtable連接random pointer。(注意,是新建的random節點,不是舊的節點。)

/** * Definition for singly-linked list with a random pointer. * class RandomListNode { *     int label; *     RandomListNode next, random; *     RandomListNode(int x) { this.label = x; } * }; */public class Solution {    public RandomListNode copyRandomList(RandomListNode head) {        if (head == null) {            return null;        }                HashMap<RandomListNode, RandomListNode> nodeNewNode = new HashMap<RandomListNode, RandomListNode>();        RandomListNode cur = head;        RandomListNode dummy = new RandomListNode(-1); // new linkedlist's dummy        RandomListNode backDummy = dummy;        RandomListNode tmp = null;                while (cur != null) {            tmp = new RandomListNode(cur.label);            dummy.next = tmp;            nodeNewNode.put(cur,tmp);            cur = cur.next;            dummy = dummy.next;        }                // scan the new linked list and write the random pointers        cur = head;        RandomListNode newHead = backDummy.next;        while (cur != null && newHead != null) {            RandomListNode randomTmp = nodeNewNode.get(cur.random);            newHead.random = randomTmp;            cur = cur.next;            newHead = newHead.next;        }                return backDummy.next;    }}

方法二:Follow up的題目如果是想利用空間復雜度為O(1)的方法實現呢?這時候就要巧妙一點了。具體的圖可以參考鏈接:http://blog.csdn.net/firehotest/article/details/52665467。簡而言之,就是先把復制的節點放在原節點后面,然后再掃一遍的時候,復制random域和斷開多余的鏈接。(明天寫這個版本)

/** * Definition for singly-linked list with a random pointer. * class RandomListNode { *     int label; *     RandomListNode next, random; *     RandomListNode(int x) { this.label = x; } * }; */public class Solution {    public RandomListNode copyRandomList(RandomListNode head) {        if (head == null) {            return null;        }                RandomListNode tmp = null;        RandomListNode cur = head;        RandomListNode prev = null;                while (cur != null) {            prev = cur;            cur = cur.next;                        tmp = new RandomListNode(prev.label);            tmp.next = cur;            prev.next = tmp;        }                //connect the random fields        cur = head.next;        prev = head;        tmp = cur;                while (cur != null) {            if (prev.random != null) {                cur.random = prev.random.next;            } else {                cur.random = null;            }                                    if (cur.next == null) {                break;            }            prev = prev.next.next;            cur = cur.next.next;        }                cur = head.next;        prev = head;                //disconnect the copy and origin        while (cur != null) {            prev.next = cur.next;            if (cur.next != null) {                cur.next = cur.next.next;            } else {                cur.next = null;                break;            }            prev = prev.next;            cur = cur.next;        }                return tmp;    }}

4/ (121.) Best Time to Buy and Sell Stock

這道題的做法參考插入排序的做法,設立一個變量作為臨時的結果變量,不斷更新,直到遍歷完整個數組。在這里的臨時結果變量有哪些呢?想要獲得最大的profit,必須是以當前的或者之后的價格減去目前已有的最小價格。

所以這道題應該這么做:

public class Solution {    public int maxProfit(int[] prices) {        if (prices == null || prices.length == 0) {            return 0;        }                int profit = 0;        int minPrice = prices[0];                for (int i = 0; i < prices.length; i++) {            if (prices[i] < minPrice) {                minPrice = prices[i];            }            for (int j = i + 1; j < prices.length; j++) {                profit = Math.max(profit, prices[j] - minPrice);            }        }                return profit;    }}但這個算法其實不用寫兩個循環,可以用一個算法解決:

public class Solution {    public int maxProfit(int[] prices) {        if (prices == null || prices.length == 0) {            return 0;        }                int minPrice = prices[0];        int profit = 0;                for (int tmp : prices) {            if (tmp < minPrice) {                minPrice = tmp;            }                        profit = Math.max(profit, tmp - minPrice);        }                return profit;    }}之前還寫過一個算法,實現把每一個時間點買入的最大profit求出來,更新最大的profit即可。但還是上述的方法最簡單。

5/ (283.) Move Zeroes

Given an array nums, write a function to move all 0's to the end of it while maintaining the relative order of the non-zero elements.For example, given nums = [0, 1, 0, 3, 12], after calling your function, nums should be [1, 3, 12, 0, 0].Note:You must do this in-place without making a copy of the array.Minimize the total number of Operations.

其實這道題的思路也十分簡單,利用移位復制的方法,這個方法稱為insertion index. 

public class Solution {    public void moveZeroes(int[] nums) {        int index = 0;        int n = 0;                while (n < nums.length) {            if (nums[n] != 0) {                nums[index++] = nums[n];            }            n = n + 1;        }                while (index < nums.length) {            nums[index++] = 0;        }    }}

6/ (1.) Two Sum

Given an array of integers, return indices of the two numbers such that they add up to a specific target.You may assume that each input would have exactly one solution, and you may not use the same element twice.Example:Given nums = [2, 7, 11, 15], target = 9,Because nums[0] + nums[1] = 2 + 7 = 9,return [0, 1].

public class Solution {    public int[] twoSum(int[] nums, int target) {        if (nums == null || nums.length < 2) {            return null;        }                HashMap<Integer, Integer> valIndex = new HashMap<Integer, Integer>();        for (int i = 0; i < nums.length; i++) {            if (valIndex.containsKey(target - nums[i])) {                return new int[]{i,valIndex.get(target - nums[i])};            } else {                valIndex.put(nums[i],i);            }        }        return new int[2];    }}

這題犯的錯是,一開始打算把所有的值當做key,然后存在index作為value。但是,漏了考慮要是有重復值的話,就會被覆蓋了。只有像答案這樣,優先檢查是否有匹配值,有匹配值就馬上匹配就好。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲精品永久免费| 亚洲欧洲视频在线| 国产精品青青在线观看爽香蕉| 最新国产精品拍自在线播放| 亚洲欧美日韩中文视频| 亚洲免费伊人电影在线观看av| 成人在线精品视频| 成人激情视频在线观看| 成人免费xxxxx在线观看| 一色桃子一区二区| 欧美日韩视频在线| 亚洲成人性视频| 欧美视频二区36p| 日韩三级影视基地| 欧美性69xxxx肥| 久久亚洲精品一区二区| 久久精品视频在线观看| 精品国产一区二区三区四区在线观看| 国产精品伦子伦免费视频| 欧美激情videoshd| 成人亚洲欧美一区二区三区| 一区二区三区久久精品| 亚洲国产97在线精品一区| 日韩精品在线免费| 91精品在线一区| 中文字幕日韩欧美在线| 一区二区三区 在线观看视| 色七七影院综合| 国产裸体写真av一区二区| 国产精品一区二区三区在线播放| 91影院在线免费观看视频| 国产视频精品一区二区三区| 久久久人成影片一区二区三区| 久久五月天综合| 亚洲国产婷婷香蕉久久久久久| 亚洲男女性事视频| 欧美日韩免费网站| 一本色道久久88综合亚洲精品ⅰ| 日韩精品福利在线| 精品久久香蕉国产线看观看gif| 欧美日韩成人在线播放| 国产成人精品久久亚洲高清不卡| 国产精品99久久久久久久久| 国产视频999| 亚洲日本中文字幕| 欧美网站在线观看| 久久精品视频在线播放| 26uuu国产精品视频| 夜夜嗨av一区二区三区免费区| 国产激情综合五月久久| 97在线视频观看| 成人免费视频xnxx.com| 国产精品视频久久| 一本一本久久a久久精品牛牛影视| 国产亚洲欧美日韩精品| 日本亚洲欧美成人| 97av在线视频免费播放| 久久久99免费视频| 国内精久久久久久久久久人| 国产精品第二页| 2019日本中文字幕| 国产精品444| 欧美精品午夜视频| 日韩电影免费在线观看中文字幕| 综合激情国产一区| 亚洲欧洲在线免费| zzjj国产精品一区二区| 国产成人精品日本亚洲专区61| 日韩免费在线视频| 尤物tv国产一区| 日韩大片在线观看视频| 午夜美女久久久久爽久久| 亚洲精品二三区| 国产精品自拍偷拍| 中文字幕欧美精品日韩中文字幕| www日韩中文字幕在线看| 成人国产精品久久久| 色偷偷91综合久久噜噜| 69久久夜色精品国产69| 国产成人精品久久二区二区| 亚洲国产精品国自产拍av秋霞| 成人免费午夜电影| 欧美黑人狂野猛交老妇| 亚洲毛茸茸少妇高潮呻吟| 日韩综合视频在线观看| 国产主播在线一区| 91精品一区二区| 亚洲第一在线视频| 欧美色图在线视频| 亚洲一区亚洲二区| 日韩欧美a级成人黄色| 久久综合久中文字幕青草| 亚洲九九九在线观看| 色偷偷888欧美精品久久久| 亚洲自拍中文字幕| 欧美日韩在线视频首页| 久久免费视频网站| 亚洲欧美日韩中文在线| 国产丝袜高跟一区| 日韩精品有码在线观看| 成人网在线视频| 日韩高清欧美高清| 亚洲国产精品久久91精品| 亚洲精品日韩av| 欧美老肥婆性猛交视频| 欧美国产欧美亚洲国产日韩mv天天看完整| 色黄久久久久久| 国产91色在线|| 久久99国产综合精品女同| 国产极品jizzhd欧美| 欧美精品在线免费| 亚洲欧美三级伦理| 国产精品高潮呻吟久久av无限| 日韩美女免费观看| 国产精品久久久久久久电影| 国产福利视频一区二区| 综合网中文字幕| 成人国产精品久久久| 日韩中文有码在线视频| 亚洲自拍偷拍福利| 91九色综合久久| 韩国v欧美v日本v亚洲| 亚洲大胆人体av| 丝袜美腿精品国产二区| 成人av电影天堂| 国产一级揄自揄精品视频| 日韩电影在线观看永久视频免费网站| 亚洲国产又黄又爽女人高潮的| 91精品国产九九九久久久亚洲| 亚洲电影天堂av| 5278欧美一区二区三区| 欧美精品www在线观看| 欧美精品久久久久| 久久久久亚洲精品成人网小说| 欧美理论电影在线观看| 国产精品高潮呻吟久久av无限| 欧美一区二粉嫩精品国产一线天| 5566日本婷婷色中文字幕97| 亚洲欧美色婷婷| 中文字幕欧美日韩va免费视频| 国产日韩欧美另类| 欧美极品少妇xxxxx| 亚洲无av在线中文字幕| 日韩av电影在线网| 色婷婷**av毛片一区| 91美女片黄在线观看游戏| 久久精品国产2020观看福利| 国产精品香蕉av| 91久久精品国产91性色| 一本大道香蕉久在线播放29| 午夜精品一区二区三区在线播放| 日韩精品中文字幕视频在线| 亚洲一区国产精品| 欧美日韩国产综合视频在线观看中文| 国产日韩av高清| 国产精品网红直播| 精品激情国产视频| 成人av.网址在线网站| 久色乳综合思思在线视频| 日韩av一区在线| 2019中文字幕在线| 992tv在线成人免费观看| 国产日韩欧美一二三区| 91欧美精品午夜性色福利在线|