超硬核!我統計了BAT筆試面試出現頻率最高的五道題,學會了總能碰到一道

所以說不要怕算法,簡單的題反而出現的頻率最高,不一定非要寫個幾百道才面試

兩數之和

給定一個整數數組 nums?和一個目標值 target,請你在該數組中找出和為目標值的那?兩個?整數,并返回他們的數組下標。

你可以假設每種輸入只會對應一個答案。但是,你不能重復利用這個數組中同樣的元素。

示例:

給定 nums = [2, 7, 11, 15], target = 9

因為 nums[0] + nums[1] = 2 + 7 = 9
所以返回 [0, 1]

思路:

遇到的數字裝到hashmap中,遇到的新數字查找有沒有答案int dif = target - nums[i];

class Solution {public int[] twoSum(int[] nums, int target) {HashMap<Integer,Integer> map = new HashMap<>();int[] res = new int[2];for (int i = 0; i < nums.length; i++) {int dif = target - nums[i];if (map.get(dif) != null) {res[0] = map.get(dif);res[1] = i;return res;}map.put(nums[i],i);}return res;}
}

?

?

反轉鏈表

示例:

輸入: 1->2->3->4->5->NULL
輸出: 5->4->3->2->1->NULL
進階:
你可以迭代或遞歸地反轉鏈表。你能否用兩種方法解決這道題?

?

經典題,一i個循環做那四個經典操作,自己拿紙筆畫一畫就懂啦。

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

?

有效的括號

給定一個只包括 '(',')','{','}','[',']'?的字符串,判斷字符串是否有效。

有效字符串需滿足:

左括號必須用相同類型的右括號閉合。左括號必須以正確的順序閉合。注意空字符串可被認為是有效字符串。

示例 1:

輸入: "()"
輸出: true
示例?2:

輸入: "()[]{}"
輸出: true
示例?3:

輸入: "(]"
輸出: false
示例?4:

輸入: "([)]"
輸出: false
示例?5:

輸入: "{[]}"
輸出: true

思路:

初始化棧 。一次處理表達式的每個括號。

  1. 如果遇到開括號,我們只需將其推到棧上即可。這意味著我們將稍后處理它。
  2. 如果我們遇到一個閉括號,那么我們檢查棧頂的元素。如果棧頂的元素是一個 相同類型的 左括號,那么我們將它從棧中彈出并繼續處理。否則表達式無效。

如果到最后我們剩下的棧中仍然有元素,那么表達式無效。

class Solution {// Hash table that takes care of the mappings.private HashMap<Character, Character> mappings;// Initialize hash map with mappings. This simply makes the code easier to read.public Solution() {this.mappings = new HashMap<Character, Character>();this.mappings.put(')', '(');this.mappings.put('}', '{');this.mappings.put(']', '[');}public boolean isValid(String s) {// Initialize a stack to be used in the algorithm.Stack<Character> stack = new Stack<Character>();for (int i = 0; i < s.length(); i++) {char c = s.charAt(i);// If the current character is a closing bracket.if (this.mappings.containsKey(c)) {// Get the top element of the stack. If the stack is empty, set a dummy value of '#'char topElement = stack.empty() ? '#' : stack.pop();// If the mapping for this bracket doesn't match the stack's top element, return false.if (topElement != this.mappings.get(c)) {return false;}} else {// If it was an opening bracket, push to the stack.stack.push(c);}}// If the stack still contains elements, then it is an invalid expression.return stack.isEmpty();}
}

爬樓梯/跳臺階

一只青蛙一次可以跳上1級臺階,也可以跳上2級。求該青蛙跳上一個n級的臺階總共有多少種跳法。

找遞推關系:

1)跳一階,就一種方法

2)跳兩階,它可以一次跳兩個,也可以一個一個跳,所以有兩種

3)三個及三個以上,假設為n階,青蛙可以是跳一階來到這里,或者跳兩階來到這里,只有這兩種方法。

它跳一階來到這里,說明它上一次跳到n-1階,

同理,它也可以從n-2跳過來

f(n)為跳到n的方法數,所以,f(n)=f(n-1)+f(n-2)


class Solution {public int climbStairs(int n) {int[] dp = new int[n + 1];dp[0] = 1;dp[1] = 1;for(int i = 2; i <= n; i++) {dp[i] = dp[i - 1] + dp[i - 2];}return dp[n];}
}

合并鏈表

將兩個升序鏈表合并為一個新的 升序 鏈表并返回。新鏈表是通過拼接給定的兩個鏈表的所有節點組成的。?

?

示例 1:


輸入:l1 = [1,2,4], l2 = [1,3,4]
輸出:[1,1,2,3,4,4]
示例 2:

輸入:l1 = [], l2 = []
輸出:[]
示例 3:

輸入:l1 = [], l2 = [0]
輸出:[0]
?

提示:

兩個鏈表的節點數目范圍是 [0, 50]
-100 <= Node.val <= 100
l1 和 l2 均按 非遞減順序 排列

思路:歸并的思想,一直比較兩邊的大小并且插入。

class Solution {public ListNode mergeTwoLists(ListNode l1, ListNode l2) {ListNode prehead = new ListNode(-1);ListNode prev = prehead;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;}// 合并后 l1 和 l2 最多只有一個還未被合并完,我們直接將鏈表末尾指向未合并完的鏈表即可prev.next = l1 == null ? l2 : l1;return prehead.next;}
}

?

?

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/443963.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/443963.shtml
英文地址,請注明出處:http://en.pswp.cn/news/443963.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

不騙你,全網首創的超硬核的萬字SQL題

因為上次發了數據庫原理總結&#xff0c;瀏覽快上萬了&#xff0c;所以把我總結的題目 也送給大家 上次的數據庫原理總結 一&#xff0e;根據員工工資計算其個人所得稅&#xff0c;3000元為起征點&#xff0c;超出3000元的部分按照10%的比例征收個人所得稅&#xff0c;例如&…

學姐面了美團阿里京東的面經

很真實的經歷&#xff0c;美團阿里京東全都嘗試過。希望對你們都有幫助 近一個多月 斷斷續續參加了一些校園秋季招聘&#xff0c;仍未上岸。 記錄近段時間的反思共享。 &#xff08;時間順序&#xff09; 【美團基礎研發部門-測試開發崗(功能測試&#xff0c;測試平臺研發&a…

學姐騰訊產品面經

順利拿到sp offer&#xff0c;不服不行&#xff0c;不是這塊料呀 系列文章歷史&#xff1a; 朋友面神策數據庫&#xff0c;第五個問題不會&#xff0c;直接再見 美女學姐面了美團阿里京東&#xff0c;這些經驗實在太真實了 首先&#xff0c;來個背景介紹&#xff1a; 騰訊實…

關于阿里云服務器本地訪問不了的問題

一&#xff1a;前幾天公司購買了一臺阿里云服務器&#xff0c;讓我把之前的項目都移到阿里云服務器上&#xff0c;我為此專門的研究了一下阿里云服務器的基本操作和安裝流程&#xff0c;這里我說一下我們公司的服務器配置如下&#xff1a; 系統就配置就是這個情況&#xff0c;下…

超硬核!十萬字c++題,讓你秒殺老師和面試官(上)

我發現呀&#xff0c;這大家對面試題的需求還是很大的&#xff0c;這里總結了上千道知識點&#xff0c;能換您一個收藏嗎 C 引用和指針的區別&#xff1f; 指針是一個實體&#xff0c;需要分配內存空間。引用只是變量的別名&#xff0c;不需要分配內存空間。 引用在定義的時候…

當年,學姐把這份Java總結給我,讓我在22k的校招王者局亂殺

可以說&#xff0c;學姐給我的這份文檔真的把我的知識查漏補缺&#xff0c;面試問到了好多&#xff0c;值得收藏。 并發編程 一.Executor 為什么使用線程池&#xff1a;手動創建線程耗費性能&#xff0c;不利于管理。 首先創建線程池有兩種方式&#xff1a;使用Executors工廠…

十萬字cpp成神總結-看完月薪25k

最近會放出cpp成神之路的所有總結&#xff0c;大家感興趣的可以收藏一波。 歷史文章&#xff1a; 超硬核&#xff01;十萬字c題&#xff0c;讓你秒殺老師和面試官 位運算 若一個數m滿足 m 2^n;那么k%mk&(m-1) 為什么內存對齊 平臺原因(移植原因)不是所有的硬件平臺都能…

測試必經之路(探索性測試)

接下來&#xff0c;百萬年薪測試方面也會有專題哦。 測試計劃&#xff1a; 測試范圍、方法、資源、進度、風險 測試報告&#xff1a; 就是把測試的過程和結果寫成文檔&#xff0c;對發現的問題和缺陷進行分析。 一、探索性測試 評估測試用例的標準 1 測試用例對被測對象的…

超硬核萬字!web前端學霸筆記,學完就去找工作吧

近期應粉絲要求&#xff0c;出多個前端大總結&#xff0c;適合小白復習查閱 #第一章 Web基礎知識 Web開發基本概念 1、萬維網是一個由許多相互鏈接的超文本組成的系統&#xff0c;通過互聯網訪問。 2、web&#xff1a;worldwideweb&#xff0c;萬維網&#xff0c;簡稱web&…

金額轉換,阿拉伯數字的金額轉換成中國傳統的形式如:(¥1011)-(一千零一拾一元整)輸出。...

程序代碼如下&#xff1a; package cn.itcast.framework.interview;import java.text.NumberFormat; import java.util.HashMap;//金額轉換&#xff0c;阿拉伯數字的金額轉換成中國傳統的形式如&#xff1a;&#xff08;&#xffe5;1011&#xff09;&#xff0d;>&#xff…

大學四年自學進BAT,私下存的資源/工具/網站我全貢獻出來了

這些工具/網站是我橫掃BAT的重要一步&#xff0c;甚至是決定性的一步。以后會更簡歷書寫、面試筆試、大學學習、工具等文章。 大學四年&#xff0c;上課是不可能一直上課的&#xff0c;看課本也是不可能一直看課本的。 不是說老師教的不好&#xff0c;教材寫的不好&#xff0c…

我是CSDN最硬核作者,誰贊成,誰反對?

也許是現在&#xff0c;也許是未來&#xff0c;我是全網最硬核的作者&#xff0c;最值得愛學習愛編程的崽崽們關注的作者。 一、介紹自己 哈嘍大家好&#xff0c;我是兔老大&#xff0c;之前叫過兔兔兔兔兔兔、兔兔RabbitMQ等&#xff0c;反正都是兔子啦&#xff0c;自從大學…

當年,學姐總結奇安信18k常問面試題

她確實拿了18k&#xff0c;真人真事&#xff0c;也不是很高&#xff0c;我沒必要編。 黑色字為問題&#xff0c;紅色字為答案&#xff0c;空行為一個面試過程 自我介紹 家在哪&#xff0c;工作地 測試需要掌握啥 V模型W模型 最典型的V模型版本一般會在其開始部分對軟件開發…

最強阿里巴巴歷年經典面試題匯總:C++研發崗

這個系列計劃收集幾百份朋友和讀者的面經&#xff0c;作者合集方便查看&#xff0c;各位有面經屯著可以聯系我哦 本系列歷史文章&#xff1a; 關于我的那些面經——百度后端&#xff08;附答案&#xff09; 《關于我的那些面經》滴滴Java崗&#xff08;附答案&#xff09; 朋…

當年,兔子學姐靠這個面試小抄拿了個22k

本文順序是操作系統&#xff08;jvm&#xff09;、網絡、數據庫&#xff08;mysql/redis&#xff09;&#xff0c;都是當時兔子的學姐準備面試的時候總結的&#xff0c;學生面試基本不會跑出這個范圍&#xff0c;懂行的應該能看出來。 學姐原話&#xff1a;因為我本身的知識是A…

用JAVA SOCKET編程,讀服務器幾個字符,再寫入本地顯示

Server: package cn.itcast.framework.socket;import java.io.BufferedReader; import java.io.IOException; import java.io.InputStreamReader; import java.io.PrintWriter; import java.net.ServerSocket; import java.net.Socket;//用JAVA SOCKET編程&#xff0c;讀服務器…

學姐,來挑戰字節最牛部門

字節&#xff08;分布式圖數據庫研發工程師&#xff09;真實面經&#xff0c;其實是個學長&#xff0c;但是同學們都叫他學姐&#xff0c;可能是因為帥到把女生都比下去了。 本系列歷史文章&#xff1a; 最強阿里巴巴歷年經典面試題匯總&#xff1a;C研發崗 關于我的那些面經…

學姐百度實習面經(輕松拿offer)

本系列歷史文章&#xff1a; 學姐&#xff0c;來挑戰字節最牛部門 最強阿里巴巴歷年經典面試題匯總&#xff1a;C研發崗 關于我的那些面經——百度后端&#xff08;附答案&#xff09; 《關于我的那些面經》滴滴Java崗&#xff08;附答案&#xff09; 朋友面神策數據庫&am…

阿里巴巴歷年經典面試題匯總:Java崗

這個系列計劃收集幾百份朋友和讀者的面經&#xff0c;作者合集方便查看&#xff0c;各位有面經屯著可以聯系我哦 本系列歷史文章&#xff1a; 學姐百度實習面經 學姐&#xff0c;來挑戰字節最牛部門 最強阿里巴巴歷年經典面試題匯總&#xff1a;C研發崗 關于我的那些面經—…

超經典,阿里巴巴歷年高頻面試題匯總:前端崗

這個系列計劃收集幾百份朋友和讀者的面經&#xff0c;作者合集方便查看&#xff0c;各位有面經屯著可以聯系我哦 本系列歷史文章&#xff1a; 阿里巴巴歷年經典面試題匯總&#xff1a;Java崗 學姐百度實習面經 學姐&#xff0c;來挑戰字節最牛部門 最強阿里巴巴歷年經典面試…