注冊 | 登錄讀書好,好讀書,讀好書!
讀書網(wǎng)-DuShu.com
當前位置: 首頁出版圖書科學技術(shù)計算機/網(wǎng)絡(luò)軟件與程序設(shè)計程序員代碼面試指南:IT名企算法與數(shù)據(jù)結(jié)構(gòu)題目最優(yōu)解(第2版)

程序員代碼面試指南:IT名企算法與數(shù)據(jù)結(jié)構(gòu)題目最優(yōu)解(第2版)

程序員代碼面試指南:IT名企算法與數(shù)據(jù)結(jié)構(gòu)題目最優(yōu)解(第2版)

定 價:¥109.00

作 者: 左程云 著
出版社: 電子工業(yè)出版社
叢編項:
標 簽: 暫缺

ISBN: 9787121354861 出版時間: 2019-01-01 包裝: 平裝
開本: 16開 頁數(shù): 576 字數(shù):  

內(nèi)容簡介

  《程序員代碼面試指南(第2版)》是一本程序員代碼面試寶典!書中對IT名企代碼面試各類題目的至優(yōu)解進行了總結(jié),并提供了相關(guān)代碼實現(xiàn)。針對當前程序員面試缺乏題目匯總這一痛點,本書選取將近200道真實出現(xiàn)過的經(jīng)典代碼面試題,幫助廣大程序員做充分的面試準備?!八ⅰ蓖瓯緯?,你就是“題王”! 《程序員代碼面試指南(第2版)》采用“題目+解答”的方式組織內(nèi)容,并把面試題類型相近或者解法相近的題目盡量放在一起,讀者在學習本書時很容易看出面試題解法之間的聯(lián)系,使知識的學習避免碎片化。本書將所有的面試題從難到易依次分為“將”“?!薄拔尽薄笆俊彼膫€檔次,方便讀者有針對性地選擇“刷”題。本書收錄的所有面試題都給出了至優(yōu)解講解和代碼實現(xiàn),并且提供了一些普通解法和至優(yōu)解法的運行時間對比,讓讀者真切地感受到至優(yōu)解的魅力! 《程序員代碼面試指南:(第2版)》中的題目全面且經(jīng)典,更重要的是,書中收錄了大量新題目和至優(yōu)解分析,這些內(nèi)容源自筆者多年來“死磕自己”的深入思考。 程序員們做好準備在IT名企的面試中脫穎而出、一舉成名了嗎?《程序員代碼面試指南(第2版)》就是你應(yīng)該擁有的“神兵利器”。當然,對需要提升算法和數(shù)據(jù)結(jié)構(gòu)等方面能力的程序員而言,《程序員代碼面試指南(第2版)》的價值也是顯而易見的。

作者簡介

  左程云,本科和碩士先后就讀于華中科技大學和芝加哥大學,在多家國內(nèi)外優(yōu)秀互聯(lián)網(wǎng)公司工作多年。自2010年起專注刷題至今,從2015年開始利用業(yè)余時間在??途W(wǎng)平臺針對代碼面試與算法開始教學工作。

圖書目錄

【目錄】

第1章 棧和隊列
└ 設(shè)計一個有g(shù)etMin功能的棧
└ 由兩個棧組成的隊列
└ 如何僅用遞歸函數(shù)和棧操作逆序一個棧
└ 貓狗隊列
└ 用一個棧實現(xiàn)另一個棧的排序
└ 用棧來求解漢諾塔問題
└ 生成窗口最大值數(shù)組
└ 單調(diào)棧結(jié)構(gòu)
└ 求最大子矩陣的大小
└ 最大值減去最小值小于或等于num的子數(shù)組數(shù)量

第2章 鏈表問題
└ 可見的山峰對數(shù)量
└ 打印兩個有序鏈表的公共部分
└ 在單鏈表和雙鏈表中刪除倒數(shù)第K個節(jié)點
└ 刪除鏈表的中間節(jié)點和a/b處的節(jié)點
└ 反轉(zhuǎn)單向和雙向鏈表
└ 反轉(zhuǎn)部分單向鏈表
└ 環(huán)形單鏈表的約瑟夫問題
└ 判斷一個鏈表是否為回文結(jié)構(gòu)
└ 將單向鏈表按某值劃分成左邊小、中間相等、右邊大的形式
└ 復制含有隨機指針節(jié)點的鏈表
└ 兩個單鏈表生成相加鏈表
└ 兩個單鏈表相交的一系列問題
└ 將單鏈表的每K個節(jié)點之間逆序
└ 刪除無序單鏈表中值重復出現(xiàn)的節(jié)點
└ 在單鏈表中刪除指定值的節(jié)點
└ 將搜索二叉樹轉(zhuǎn)換成雙向鏈表
└ 單鏈表的選擇排序
└ 一種怪異的節(jié)點刪除方式
└ 向有序的環(huán)形單鏈表中插入新節(jié)點
└ 合并兩個有序的單鏈表
└ 按照左右半?yún)^(qū)的方式重新組合單鏈表

第3章 二叉樹問題
└ 分別用遞歸和非遞歸方式實現(xiàn)二叉樹先序、中序和后序遍歷
└ 打印二叉樹的邊界節(jié)點
└ 如何較為直觀地打印二叉樹
└ 二叉樹的序列化和反序列化
└ 遍歷二叉樹的神級方法
└ 在二叉樹中找到累加和為指定值的最長路徑長度
└ 找到二叉樹中的最大搜索二叉子樹
└ 找到二叉樹中符合搜索二叉樹條件的最大拓撲結(jié)構(gòu)
└ 二叉樹的按層打印與ZigZag打印
└ 調(diào)整搜索二叉樹中兩個錯誤的節(jié)點
└ 判斷t1樹是否包含t2樹全部的拓撲結(jié)構(gòu)
└ 判斷t1樹中是否有與t2樹拓撲結(jié)構(gòu)完全相同的子樹
└ 判斷二叉樹是否為平衡二叉樹
└ 根據(jù)后序數(shù)組重建搜索二叉樹
└ 判斷一棵二叉樹是否為搜索二叉樹和完全二叉樹
└ 通過有序數(shù)組生成平衡搜索二叉樹
└ 在二叉樹中找到一個節(jié)點的后繼節(jié)點
└ 在二叉樹中找到兩個節(jié)點的最近公共祖先
└ Tarjan算法與并查集解決二叉樹節(jié)點間最近公共祖先的批量查詢問題
└ 二叉樹節(jié)點間的最大距離問題
└ 派對的最大快樂值
└ 通過先序和中序數(shù)組生成后序數(shù)組
└ 統(tǒng)計和生成所有不同的二叉樹
└ 統(tǒng)計完全二叉樹的節(jié)點數(shù)

第4章 遞歸和動態(tài)規(guī)劃
└ 斐波那契數(shù)列問題的遞歸和動態(tài)規(guī)劃
└ 矩陣的最小路徑和
└ 換錢的最少貨幣數(shù)
└ 機器人達到指定位置方法數(shù)
└ 換錢的方法數(shù)
└ 打氣球的最大分數(shù)
└ 最長遞增子序列
└ 信封嵌套問題
└ 漢諾塔問題
└ 最長公共子序列問題
└ 最長公共子串問題
└ 子數(shù)組異或和為0的最多劃分
└ 最小編輯代價
└ 字符串的交錯組成
└ 龍與地下城游戲問題
└ 數(shù)字字符串轉(zhuǎn)換為字母組合的種數(shù)
└ 表達式得到期望結(jié)果的組成種數(shù)
└ 排成一條線的紙牌博弈問題
└ 跳躍游戲
└ 數(shù)組中的最長連續(xù)序列
└ N皇后問題

第5章 字符串問題
└ 判斷兩個字符串是否互為變形詞
└ 判斷兩個字符串是否互為旋轉(zhuǎn)詞
└ 將整數(shù)字符串轉(zhuǎn)成整數(shù)值
└ 字符串的統(tǒng)計字符串
└ 判斷字符數(shù)組中是否所有的字符都只出現(xiàn)過一次
└ 在有序但含有空的數(shù)組中查找字符串
└ 字符串的調(diào)整與替換
└ 翻轉(zhuǎn)字符串
└ 完美洗牌問題
└ 刪除多余字符得到字典序最小的字符串
└ 數(shù)組中兩個字符串的最小距離
└ 字符串的轉(zhuǎn)換路徑問題
└ 添加最少字符使字符串整體都是回文字符串
└ 括號字符串的有效性和最長有效長度
└ 公式字符串求值
└ 0左邊必有1的二進制字符串數(shù)量
└ 拼接所有字符串產(chǎn)生字典順序最小的大寫字符串
└ 找到字符串的最長無重復字符子串
└ 找到指定的新類型字符
└ 旋變字符串問題
└ 最小包含子串的長度
└ 回文最少分割數(shù)
└ 字符串匹配問題
└ 字典樹(前綴樹)的實現(xiàn)
└ 子數(shù)組的最大異或和

第6章 大數(shù)據(jù)和空間限制
└ 認識布隆過濾器
└ 只用2GB內(nèi)存在20億個整數(shù)中找到出現(xiàn)次數(shù)最多的數(shù)
└ 40億個非負整數(shù)中找到未出現(xiàn)的數(shù)
└ 找到100億個URL中重復的URL及搜索詞匯的Top K問題
└ 40億個非負整數(shù)中找到出現(xiàn)兩次的數(shù)和所有數(shù)的中位數(shù)
└ 一致性哈希算法的基本原理
└ 島問題

第7章 位運算
└ 不用額外變量交換兩個整數(shù)的值
└ 不用做任何比較判斷找出兩個數(shù)中較大的數(shù)
└ 只用位運算不用算術(shù)運算實現(xiàn)整數(shù)的加減乘除運算
└ 整數(shù)的二進制數(shù)表達中有多少個1
└ 在其他數(shù)都出現(xiàn)偶數(shù)次的數(shù)組中找到出現(xiàn)奇數(shù)次的數(shù)
└ 在其他數(shù)都出現(xiàn)k次的數(shù)組中找到只出現(xiàn)一次的數(shù)

└ 第8章 數(shù)組和矩陣問題
└ 轉(zhuǎn)圈打印矩陣
└ 將正方形矩陣順時針轉(zhuǎn)動90°
└ “之”字形打印矩陣
└ 找到無序數(shù)組中最小的k個數(shù)
└ 需要排序的最短子數(shù)組長度
└ 在數(shù)組中找到出現(xiàn)次數(shù)大于N/K的數(shù)
└ 在行列都排好序的矩陣中找指定數(shù)
└ 最長的可整合子數(shù)組的長度
└ 不重復打印排序數(shù)組中相加和為給定值的所有二元組和三元組
└ 未排序正數(shù)數(shù)組中累加和為給定值的最長子數(shù)組長度
└ 未排序數(shù)組中累加和為給定值的最長子數(shù)組系列問題
└ 未排序數(shù)組中累加和小于或等于給定值的最長子數(shù)組長度
└ 計算數(shù)組的小和
└ 自然數(shù)數(shù)組的排序
└ 奇數(shù)下標都是奇數(shù)或者偶數(shù)下標都是偶數(shù)
└ 子數(shù)組的最大累加和問題
└ 子矩陣的最大累加和問題
└ 在數(shù)組中找到一個局部最小的位置
└ 數(shù)組中子數(shù)組的最大累乘積
└ 打印N個數(shù)組整體最大的Top K
└ 邊界都是1的最大正方形大小
└ 不包含本位置值的累乘數(shù)組
└ 數(shù)組的partition調(diào)整
└ 求最短通路值
└ 數(shù)組中未出現(xiàn)的最小正整數(shù)
└ 數(shù)組排序之后相鄰數(shù)的最大差值
└ 做項目的最大收益問題
└ 分金條的最小花費
└ 大樓輪廓問題
└ 加油站良好出發(fā)點問題
└ 容器盛水問題

第9章 其他題目
└ 從5隨機到7隨機及其擴展
└ 一行代碼求兩個數(shù)的最大公約數(shù)
└ 有關(guān)階乘的兩個問題
└ 判斷一個點是否在矩形內(nèi)部
└ 判斷一個點是否在三角形內(nèi)部
└ 折紙問題
└ 能否完美地拼成矩形
└ 蓄水池算法
└ 設(shè)計有setAll功能的哈希表
└ 最大的leftMax與rightMax之差的絕對值
└ 設(shè)計LRU緩存結(jié)構(gòu)
└ LFU緩存結(jié)構(gòu)設(shè)計
└ 設(shè)計RandomPool結(jié)構(gòu)
└ 并查集的實現(xiàn)
└ 調(diào)整[0,x)區(qū)間上的數(shù)出現(xiàn)的概率
└ 路徑數(shù)組變?yōu)榻y(tǒng)計數(shù)組
└ 正數(shù)數(shù)組的最小不可組成和
└ 累加出整個范圍所有的數(shù)最少還需幾個數(shù)
└ 一種字符串和數(shù)字的對應(yīng)關(guān)系
└ 1到n中1出現(xiàn)的次數(shù)
└ 從N個數(shù)中等概率打印M個數(shù)
└ 判斷一個數(shù)是否是回文數(shù)
└ 在有序旋轉(zhuǎn)數(shù)組中找到最小值
└ 在有序旋轉(zhuǎn)數(shù)組中找到一個數(shù)
└ 數(shù)字的英文表達和中文表達
└ 分糖果問題
└ 一種消息接收并打印的結(jié)構(gòu)設(shè)計
└ 隨時找到數(shù)據(jù)流的中位數(shù)
└ 在兩個長度相等的排序數(shù)組中找到上中位數(shù)
└ 在兩個排序數(shù)組中找到第k小的數(shù)
└ 兩個有序數(shù)組間相加和的Top k問題
└ 出現(xiàn)次數(shù)的Top k問題
└ Manacher算法
└ KMP算法
└ 丟棋子問題
└ 畫匠問題
└ 郵局選址問題

本目錄推薦

掃描二維碼
Copyright ? 讀書網(wǎng) www.talentonion.com 2005-2020, All Rights Reserved.
鄂ICP備15019699號 鄂公網(wǎng)安備 42010302001612號