引入了一批來自於名牌高校、就職於明星企業的職場達人的真實求職案例,通過他們的求職經驗與教訓,拋磚引玉,將整個求職過程生動形象地展示在讀者面前,進而對求職者起到一定的指引作用。
同時,為了更具說服力,書中特邀多位IT名企面試官現身說法,以獨到的視角對面試過程中求職者存在的各類問題進行了深度剖析。
為了能夠讓讀者對即將投身的工作有一份更加清楚的認識,能夠更加有針對性地進行求職准備,《Java程序員面試筆試寶典》對各種類型的IT企業的招聘環節進行了庖丁解牛式的分析。不僅如此,書中還特別針對當前各大IT企業面試筆試中常見的問題以及注意事項,進行了深層次的分析。
技術性知識的考核是程序員求職中最重要的內容,鑒於此,《Java程序員面試筆試寶典》除了對傳統的計算機相關知識(Java語言基礎知識、Web基礎知識、數據結構與算法、操作系統、計算機網絡與通信、數據庫、設計模式等)以及面試筆試真題進行分析與解答外,還根據當前計算機技術的發展潮流,對面試筆試中常見的海量數據處理進行了詳細地分析。
《Java程序員面試筆試寶典》是一本計算機相關專業畢業生面試筆試的求職用書,同時也適合期望在計算機軟硬件行業大顯身手的計算機愛好者閱讀。
目錄
前言
上篇 面試筆試經驗技巧篇
第1章 面試官箴言
1.1 有道無術,術可求;有術無道,
止於術
1.2 求精不求全
1.3 腳踏實地,培養多種技能
1.4 保持空杯心態
1.5 職場是能者的舞台
1.6 學會「紙上談兵」
1.7 小結
第2章 面試心得交流
2.1 心態決定一切
2.2 假話全不說,真話不全說
2.3 走自己的路,讓別人去說吧
2.4 夯實基礎謀出路
2.5 書中自有編程法
2.6 筆試成績好,不會被鄙視
2.7 不要一廂情願做公司的
「備胎」
2.8 小結
第3章 企業面試筆試攻略
3.1 互聯網企業
3.2 網絡設備提供商
3.3 外企
3.4 國企
3.5 研究所
3.6 創業型企業
3.7 如何抉擇
下篇 面試筆試技術攻克篇
第4章 Java基礎知識
4.1 基本概念
4.1.1 Java語言有哪些優點
4.1.2 Java與C/C++有什麼異同
4.1.3 為什麼需要public static void
main(String[] args)這個方法
4.1.4 如何實現在main()方法執行前輸出
「Hello World」
4.1.5 Java程序初始化的順序是怎樣的
4.1.6 Java中的作用域有哪些
4.1.7 一個Java文件中是否可以定義
多個類
4.1.8 什麼是構造函數
4.1.9 為什麼Java中有些接口沒有
任何方法
4.1.1 0Java中的clone方法有什麼作用
4.1.1 1什麼是反射機制
4.1.1 2package有什麼作用
4.1.1 3如何實現類似於C語言中函數
指針的功能
4.2 面向對象技術
4.2.1 面向對象與面向過程有什麼區別
4.2.2 面向對象有哪些特征
4.2.3 面向對象的開發方式有什麼優點
4.2.4 什麼是繼承
4.2.5 組合和繼承有什麼區別
4.2.6 多態的實現機制是什麼
4.2.7 重載和覆蓋有什麼區別
4.2.8 抽象類(abstract class)與接口
(interface)有什麼異同
4.2.9 內部類有哪些
4.2.1 0如何獲取父類的類名
4.2.1 1this與super有什麼區別
4.3 關鍵字
4.3.1 變量命名有哪些規則
4.3.2 break、continue以及return有
什麼區別
4.3.3 final、 finally和 finalize有什麼
區別
4.3.4 assert有什麼作用
4.3.5 static關鍵字有哪些作用
4.3.6 使用switch時有哪些注意事項
4.3.7 volatile有什麼作用
4.3.8 instanceof有什麼作用
4.3.9 strictfp有什麼作用
4.4 基本類型與運算
4.4.1 Java提供了哪些基本數據類型
4.4.2 什麼是不可變類
4.4.3 值傳遞與引用傳遞有哪些區別
4.4.4 不同數據類型的轉換有哪些規則
4.4.5 強制類型轉換的注意事項有哪些
4.4.6 運算符優先級是什麼?
4.4.7 Math類中round、ceil和floor方法的
功能各是什麼
4.4.8 ++i與i++有什麼區別
4.4.9 如何實現無符號數的右移操作
4.4.10 char型變量中是否可以存儲一個
中文漢字
4.5 字符串與數組
4.5.1 字符串創建與存儲的機制
是什麼
4.5.2 「==」、equals和hashCode有什麼
區別
4.5.3 String、StringBuffer、StringBuilder和
StringTokenizer有什麼區別
4.5.4 Java中數組是不是對象
4.5.5 數組的初始化方式有哪幾種
4.5.6 length屬性與length()方法
有什麼區別
4.6 異常處理
4.6.1 finally塊中的代碼什麼時候
被執行
4.6.2 異常處理的原理是什麼
4.6.3 運行時異常和普通異常
有什麼區別
4.7 輸入輸出流
4.7.1 Java IO流的實現機制是什麼
4.7.2 管理文件和目錄的類是什麼
4.7.3 Java Socket是什麼
4.7.4 Java NIO是什麼
4.7.5 什麼是Java序列化
4.7.6 System.out.println()方法使用需要
注意哪些問題
4.8 Java平台與內存管理
4.8.1 為什麼說Java是平台獨立性
語言
4.8.2 Java平台與其他語言平台有哪些
區別
4.8.3 JVM加載class文件的原理機制
是什麼
4.8.4 什麼是GC
4.8.5 Java是否存在內存泄露問題
4.8.6 Java中的堆和棧有什麼區別
4.9 容器
4.9.1 Java Collections框架是什麼
4.9.2 什麼是迭代器
4.9.3 ArrayList、Vector和LinkedList
有什麼區別
4.9.4 HashMap、HashTable、TreeMap和
WeakHashMap有哪些區別
4.9.5 用自定義作為HashMap或HashTable的
key需要注意哪些問題
4.9.6 Collection和 Collections有什麼
區別
4.10 多線程
4.10.1 什麼是線程?它與進程有什麼區別?
為什麼要使用多線程
4.10.2 同步和異步有什麼區別
4.10.3 如何實現Java多線程
4.10.4 run()方法與start()方法有什麼
區別
4.10.5 多線程同步的實現方法有
哪些
4.10.6 sleep()方法與wait()方法
有什麼區別
4.10.7 終止線程的方法有哪些
4.10.8 synchronized與Lock
有什麼異同
4.10.9 什麼是守護線程
4.10.1 0join()方法的作用是什麼
4.11 Java數據庫操作
4.11.1 如何通過JDBC訪問數據庫
4.11.2 JDBC處理事務采用什麼方法
4.11.3 Class.forName的作用是什麼
4.11.4 Statement、PreparedStatement和
CallableStatement有什麼區別
4.11.5 getString()方法與getObject()
方法有什麼區別
4.11.6 使用JDBC時需要注意
哪些問題
4.11.7 什麼是JDO
4.11.8 JDBC與Hibernate有什麼區別
第5章 Java Web
5.1 Servlet與JSP
5.1.1 頁面請求的工作流程是怎樣的
5.1.2 HTTP中GET與POST方法
有什麼區別
5.1.3 什麼是Servlet
5.1.4 doPost()方法與doGet()
方法怎麼選擇
5.1.5 什麼是Servlet的生命周期
5.1.6 JSP有哪些優點
5.1.7 JSP與Servlet有何異同
5.1.8 如何使用JSP與Servlet實現
MVC模型
5.1.9 Servlet中forward和redirect
有什麼區別
5.1.1 0JSP的內置對象有哪些
5.1.1 1request對象主要有哪些方法
5.1.1 2JSP有哪些動作
5.1.1 3JSP中include指令和include動作
有什麼區別
5.1.1 4會話跟蹤技術有哪些
5.1.1 5Web開發中如何指定
字符串的編碼
5.1.1 6什麼是Ajax
5.1.1 7cookie和session有什麼區別
5.2 J2EE與EJB
5.2.1 什麼是J2EE
5.2.2 J2EE中常用的術語有哪些
5.2.3 EJB有哪些不同的類別
5.2.4 EJB與JavaBean有什麼異同
5.2.5 EJB有哪些生命周期
5.2.6 EJB的角色有哪幾種
5.2.7 EJB的開發流程是怎樣的
5.2.8 EJB 3.0與EJB 2.0有哪些
不同之處
5.2.9 EJB容器有哪些作用
5.2.1 0EJB規范規定EJB中禁止的
操作有哪些
5.2.1 1Web服務器與Web應用服務器
有什麼區別
5.2.1 2什麼是Web Service
5.2.1 3SOAP與REST有什麼區別
5.2.1 4什麼是XML
5.2.1 5數據庫連接池的工作機制
是怎樣的
5.2.1 6J2EE開發有哪些調優的方法
5.3 框架
5.3.1 什麼是Struts框架
5.3.2 Struts框架響應客戶請求的
工作流程是什麼
5.3.3 Struts框架的數據驗證可分為
幾種類型
5.3.4 Form Bean的表單驗證流程
是什麼
5.3.5 在Struts配置文件中,
元素包含哪些屬性和子元素
5.3.6 ActionForm Bean的作用有哪些
5.3.7 ActionForm的執行步驟有哪些
5.3.8 forward與global-forward
有什麼區別
5.3.9 Struts如何實現國際化
5.3.1 0Struts 1與Struts 2有哪些區別
5.3.1 1什麼是IoC
5.3.1 2什麼是AOP
5.3.1 3什麼是Spring框架
5.3.1 4什麼是Hibernate
5.3.1 5什麼是Hibernate的二級緩存
5.3.1 6Hibernate中session的update()和
saveOrUpdate()、 load()和get()
有什麼區別
5.3.1 7Hibernate有哪些主鍵
生成策略
5.3.1 8如何實現分頁機制
5.3.1 9什麼是SSH
第6章 數據庫原理
6.1 SQL語言的功能有哪些
6.2 內連接與外連接有什麼區別
6.3 什麼是事務
6.4 什麼是存儲過程?它與函數
有什麼區別與聯系
6.5 各種范式有什麼區別
6.6 什麼是觸發器
6.7 什麼是游標
6.8 如果數據庫日志滿了,會出現
什麼情況
6.9 union和union all有什麼區別
6.10 什麼是視圖
第7章 設計模式
7.1 什麼是單例模式
7.2 什麼是工廠模式
7.3 什麼是適配器模式
7.4 什麼是觀察者模式
第8章 數據結構與算法
8.1 鏈表
8.1.1 如何實現單鏈表的增刪操作
8.1.2 如何從鏈表中刪除重復數據
8.1.3 如何找出單鏈表中的倒數
第k個元素
8.1.4 如何實現鏈表的反轉
8.1.5 如何從尾到頭輸出單鏈表
8.1.6 如何尋找單鏈表的中間結點
8.1.7 如何檢測一個鏈表是否有環
8.1.8 如何在不知道頭指針的情況下
刪除指定結點
8.1.9 如何判斷兩個鏈表是否相交
8.2 棧與隊列
8.2.1 棧與隊列有哪些區別
8.2.2 如何實現棧
8.2.3 如何用O(1)的時間復雜度
求棧中最小元素
8.2.4 如何實現隊列
8.2.5 如何用兩個棧模擬隊列操作
8.3 排序
8.3.1 如何進行選擇排序
8.3.2 如何進行插入排序
8.3.3 如何進行冒泡排序
8.3.4 如何進行歸並排序
8.3.5 如何進行快速排序
8.3.6 如何進行希爾排序
8.3.7 如何進行堆排序
8.3.8 各種排序算法有什麼優劣
8.4 位運算
8.4.1 如何用移位操作實現乘法運算
8.4.2 如何判斷一個數是否
為2的n次方
8.4.3 如何求二進制數中1的個數
8.5 數組
8.5.1 如何尋找數組中的最小值與
最大值
8.5.2 如何找出數組中第二大的數
8.5.3 如何求最大子數組之和
8.5.4 如何找出數組中重復元素
最多的數
8.5.5 如何求數組中兩兩相加等於20的
組合種數
8.5.6 如何把一個數組循環右移k位
8.5.7 如何找出數組中第k個
最小的數
8.5.8 如何找出數組中只出現
一次的數字
8.5.9 如何找出數組中唯一的
重復元素
8.5.1 0如何用遞歸方法求一個整數
數組的最大元素
8.5.1 1如何求數對之差的最大值
8.5.1 2如何求絕對值最小的數
8.5.1 3如何求數組中兩個元素的
最小距離
8.5.1 4如何求指定數字在數組中第一次
出現的位置
8.5.1 5如何對數組的兩個子有序段
進行合並
8.5.1 6如何計算兩個有序整型
數組的交集
8.5.1 7如何判斷一個數組中數值
是否連續相鄰
8.5.1 8如何求解數組中反序對的
個數
8.5.1 9如何求解最小三元組距離
8.6 字符串
8.6.1 如何實現字符串的反轉
8.6.2 如何判斷兩個字符串是否由相同的
字符組成
8.6.3 如何刪除字符串中重復的字符
8.6.4 如何統計一行字符中有多少個
單詞
8.6.5 如何按要求打印數組的排列
情況
8.6.6 如何輸出字符串的所有組合
8.7 二叉樹
8.7.1 二叉樹基本概念
8.7.2 如何實現二叉排序樹
8.7.3 如何層序遍歷二叉樹
8.7.4 已知先序遍歷和中序遍歷,如何
求后序遍歷
8.7.5 如何求二叉樹中結點的
最大距離
8.8 其他
8.8.1 如何消除嵌套的括號
8.8.2 如何不使用比較運算就可以求出
兩個數的最大值與最小值
第9章 海量數據處理
9.1 問題分析
9.2 基本方法
9.3 經典實例分析
9.3.1 top K問題
9.3.2 重復問題
9.3.3 排序問題
附錄
附錄A 軟件企業Java筆試真題1
附錄B 軟件企業Java筆試真題2
附錄C 軟件企業Java筆試真題3
附錄D 求職有用網站及QQ群一覽表
上篇 面試筆試經驗技巧篇
第1章 面試官箴言
1.1 有道無術,術可求;有術無道,
止於術
1.2 求精不求全
1.3 腳踏實地,培養多種技能
1.4 保持空杯心態
1.5 職場是能者的舞台
1.6 學會「紙上談兵」
1.7 小結
第2章 面試心得交流
2.1 心態決定一切
2.2 假話全不說,真話不全說
2.3 走自己的路,讓別人去說吧
2.4 夯實基礎謀出路
2.5 書中自有編程法
2.6 筆試成績好,不會被鄙視
2.7 不要一廂情願做公司的
「備胎」
2.8 小結
第3章 企業面試筆試攻略
3.1 互聯網企業
3.2 網絡設備提供商
3.3 外企
3.4 國企
3.5 研究所
3.6 創業型企業
3.7 如何抉擇
下篇 面試筆試技術攻克篇
第4章 Java基礎知識
4.1 基本概念
4.1.1 Java語言有哪些優點
4.1.2 Java與C/C++有什麼異同
4.1.3 為什麼需要public static void
main(String[] args)這個方法
4.1.4 如何實現在main()方法執行前輸出
「Hello World」
4.1.5 Java程序初始化的順序是怎樣的
4.1.6 Java中的作用域有哪些
4.1.7 一個Java文件中是否可以定義
多個類
4.1.8 什麼是構造函數
4.1.9 為什麼Java中有些接口沒有
任何方法
4.1.1 0Java中的clone方法有什麼作用
4.1.1 1什麼是反射機制
4.1.1 2package有什麼作用
4.1.1 3如何實現類似於C語言中函數
指針的功能
4.2 面向對象技術
4.2.1 面向對象與面向過程有什麼區別
4.2.2 面向對象有哪些特征
4.2.3 面向對象的開發方式有什麼優點
4.2.4 什麼是繼承
4.2.5 組合和繼承有什麼區別
4.2.6 多態的實現機制是什麼
4.2.7 重載和覆蓋有什麼區別
4.2.8 抽象類(abstract class)與接口
(interface)有什麼異同
4.2.9 內部類有哪些
4.2.1 0如何獲取父類的類名
4.2.1 1this與super有什麼區別
4.3 關鍵字
4.3.1 變量命名有哪些規則
4.3.2 break、continue以及return有
什麼區別
4.3.3 final、 finally和 finalize有什麼
區別
4.3.4 assert有什麼作用
4.3.5 static關鍵字有哪些作用
4.3.6 使用switch時有哪些注意事項
4.3.7 volatile有什麼作用
4.3.8 instanceof有什麼作用
4.3.9 strictfp有什麼作用
4.4 基本類型與運算
4.4.1 Java提供了哪些基本數據類型
4.4.2 什麼是不可變類
4.4.3 值傳遞與引用傳遞有哪些區別
4.4.4 不同數據類型的轉換有哪些規則
4.4.5 強制類型轉換的注意事項有哪些
4.4.6 運算符優先級是什麼?
4.4.7 Math類中round、ceil和floor方法的
功能各是什麼
4.4.8 ++i與i++有什麼區別
4.4.9 如何實現無符號數的右移操作
4.4.10 char型變量中是否可以存儲一個
中文漢字
4.5 字符串與數組
4.5.1 字符串創建與存儲的機制
是什麼
4.5.2 「==」、equals和hashCode有什麼
區別
4.5.3 String、StringBuffer、StringBuilder和
StringTokenizer有什麼區別
4.5.4 Java中數組是不是對象
4.5.5 數組的初始化方式有哪幾種
4.5.6 length屬性與length()方法
有什麼區別
4.6 異常處理
4.6.1 finally塊中的代碼什麼時候
被執行
4.6.2 異常處理的原理是什麼
4.6.3 運行時異常和普通異常
有什麼區別
4.7 輸入輸出流
4.7.1 Java IO流的實現機制是什麼
4.7.2 管理文件和目錄的類是什麼
4.7.3 Java Socket是什麼
4.7.4 Java NIO是什麼
4.7.5 什麼是Java序列化
4.7.6 System.out.println()方法使用需要
注意哪些問題
4.8 Java平台與內存管理
4.8.1 為什麼說Java是平台獨立性
語言
4.8.2 Java平台與其他語言平台有哪些
區別
4.8.3 JVM加載class文件的原理機制
是什麼
4.8.4 什麼是GC
4.8.5 Java是否存在內存泄露問題
4.8.6 Java中的堆和棧有什麼區別
4.9 容器
4.9.1 Java Collections框架是什麼
4.9.2 什麼是迭代器
4.9.3 ArrayList、Vector和LinkedList
有什麼區別
4.9.4 HashMap、HashTable、TreeMap和
WeakHashMap有哪些區別
4.9.5 用自定義作為HashMap或HashTable的
key需要注意哪些問題
4.9.6 Collection和 Collections有什麼
區別
4.10 多線程
4.10.1 什麼是線程?它與進程有什麼區別?
為什麼要使用多線程
4.10.2 同步和異步有什麼區別
4.10.3 如何實現Java多線程
4.10.4 run()方法與start()方法有什麼
區別
4.10.5 多線程同步的實現方法有
哪些
4.10.6 sleep()方法與wait()方法
有什麼區別
4.10.7 終止線程的方法有哪些
4.10.8 synchronized與Lock
有什麼異同
4.10.9 什麼是守護線程
4.10.1 0join()方法的作用是什麼
4.11 Java數據庫操作
4.11.1 如何通過JDBC訪問數據庫
4.11.2 JDBC處理事務采用什麼方法
4.11.3 Class.forName的作用是什麼
4.11.4 Statement、PreparedStatement和
CallableStatement有什麼區別
4.11.5 getString()方法與getObject()
方法有什麼區別
4.11.6 使用JDBC時需要注意
哪些問題
4.11.7 什麼是JDO
4.11.8 JDBC與Hibernate有什麼區別
第5章 Java Web
5.1 Servlet與JSP
5.1.1 頁面請求的工作流程是怎樣的
5.1.2 HTTP中GET與POST方法
有什麼區別
5.1.3 什麼是Servlet
5.1.4 doPost()方法與doGet()
方法怎麼選擇
5.1.5 什麼是Servlet的生命周期
5.1.6 JSP有哪些優點
5.1.7 JSP與Servlet有何異同
5.1.8 如何使用JSP與Servlet實現
MVC模型
5.1.9 Servlet中forward和redirect
有什麼區別
5.1.1 0JSP的內置對象有哪些
5.1.1 1request對象主要有哪些方法
5.1.1 2JSP有哪些動作
5.1.1 3JSP中include指令和include動作
有什麼區別
5.1.1 4會話跟蹤技術有哪些
5.1.1 5Web開發中如何指定
字符串的編碼
5.1.1 6什麼是Ajax
5.1.1 7cookie和session有什麼區別
5.2 J2EE與EJB
5.2.1 什麼是J2EE
5.2.2 J2EE中常用的術語有哪些
5.2.3 EJB有哪些不同的類別
5.2.4 EJB與JavaBean有什麼異同
5.2.5 EJB有哪些生命周期
5.2.6 EJB的角色有哪幾種
5.2.7 EJB的開發流程是怎樣的
5.2.8 EJB 3.0與EJB 2.0有哪些
不同之處
5.2.9 EJB容器有哪些作用
5.2.1 0EJB規范規定EJB中禁止的
操作有哪些
5.2.1 1Web服務器與Web應用服務器
有什麼區別
5.2.1 2什麼是Web Service
5.2.1 3SOAP與REST有什麼區別
5.2.1 4什麼是XML
5.2.1 5數據庫連接池的工作機制
是怎樣的
5.2.1 6J2EE開發有哪些調優的方法
5.3 框架
5.3.1 什麼是Struts框架
5.3.2 Struts框架響應客戶請求的
工作流程是什麼
5.3.3 Struts框架的數據驗證可分為
幾種類型
5.3.4 Form Bean的表單驗證流程
是什麼
5.3.5 在Struts配置文件中,
元素包含哪些屬性和子元素
5.3.6 ActionForm Bean的作用有哪些
5.3.7 ActionForm的執行步驟有哪些
5.3.8 forward與global-forward
有什麼區別
5.3.9 Struts如何實現國際化
5.3.1 0Struts 1與Struts 2有哪些區別
5.3.1 1什麼是IoC
5.3.1 2什麼是AOP
5.3.1 3什麼是Spring框架
5.3.1 4什麼是Hibernate
5.3.1 5什麼是Hibernate的二級緩存
5.3.1 6Hibernate中session的update()和
saveOrUpdate()、 load()和get()
有什麼區別
5.3.1 7Hibernate有哪些主鍵
生成策略
5.3.1 8如何實現分頁機制
5.3.1 9什麼是SSH
第6章 數據庫原理
6.1 SQL語言的功能有哪些
6.2 內連接與外連接有什麼區別
6.3 什麼是事務
6.4 什麼是存儲過程?它與函數
有什麼區別與聯系
6.5 各種范式有什麼區別
6.6 什麼是觸發器
6.7 什麼是游標
6.8 如果數據庫日志滿了,會出現
什麼情況
6.9 union和union all有什麼區別
6.10 什麼是視圖
第7章 設計模式
7.1 什麼是單例模式
7.2 什麼是工廠模式
7.3 什麼是適配器模式
7.4 什麼是觀察者模式
第8章 數據結構與算法
8.1 鏈表
8.1.1 如何實現單鏈表的增刪操作
8.1.2 如何從鏈表中刪除重復數據
8.1.3 如何找出單鏈表中的倒數
第k個元素
8.1.4 如何實現鏈表的反轉
8.1.5 如何從尾到頭輸出單鏈表
8.1.6 如何尋找單鏈表的中間結點
8.1.7 如何檢測一個鏈表是否有環
8.1.8 如何在不知道頭指針的情況下
刪除指定結點
8.1.9 如何判斷兩個鏈表是否相交
8.2 棧與隊列
8.2.1 棧與隊列有哪些區別
8.2.2 如何實現棧
8.2.3 如何用O(1)的時間復雜度
求棧中最小元素
8.2.4 如何實現隊列
8.2.5 如何用兩個棧模擬隊列操作
8.3 排序
8.3.1 如何進行選擇排序
8.3.2 如何進行插入排序
8.3.3 如何進行冒泡排序
8.3.4 如何進行歸並排序
8.3.5 如何進行快速排序
8.3.6 如何進行希爾排序
8.3.7 如何進行堆排序
8.3.8 各種排序算法有什麼優劣
8.4 位運算
8.4.1 如何用移位操作實現乘法運算
8.4.2 如何判斷一個數是否
為2的n次方
8.4.3 如何求二進制數中1的個數
8.5 數組
8.5.1 如何尋找數組中的最小值與
最大值
8.5.2 如何找出數組中第二大的數
8.5.3 如何求最大子數組之和
8.5.4 如何找出數組中重復元素
最多的數
8.5.5 如何求數組中兩兩相加等於20的
組合種數
8.5.6 如何把一個數組循環右移k位
8.5.7 如何找出數組中第k個
最小的數
8.5.8 如何找出數組中只出現
一次的數字
8.5.9 如何找出數組中唯一的
重復元素
8.5.1 0如何用遞歸方法求一個整數
數組的最大元素
8.5.1 1如何求數對之差的最大值
8.5.1 2如何求絕對值最小的數
8.5.1 3如何求數組中兩個元素的
最小距離
8.5.1 4如何求指定數字在數組中第一次
出現的位置
8.5.1 5如何對數組的兩個子有序段
進行合並
8.5.1 6如何計算兩個有序整型
數組的交集
8.5.1 7如何判斷一個數組中數值
是否連續相鄰
8.5.1 8如何求解數組中反序對的
個數
8.5.1 9如何求解最小三元組距離
8.6 字符串
8.6.1 如何實現字符串的反轉
8.6.2 如何判斷兩個字符串是否由相同的
字符組成
8.6.3 如何刪除字符串中重復的字符
8.6.4 如何統計一行字符中有多少個
單詞
8.6.5 如何按要求打印數組的排列
情況
8.6.6 如何輸出字符串的所有組合
8.7 二叉樹
8.7.1 二叉樹基本概念
8.7.2 如何實現二叉排序樹
8.7.3 如何層序遍歷二叉樹
8.7.4 已知先序遍歷和中序遍歷,如何
求后序遍歷
8.7.5 如何求二叉樹中結點的
最大距離
8.8 其他
8.8.1 如何消除嵌套的括號
8.8.2 如何不使用比較運算就可以求出
兩個數的最大值與最小值
第9章 海量數據處理
9.1 問題分析
9.2 基本方法
9.3 經典實例分析
9.3.1 top K問題
9.3.2 重復問題
9.3.3 排序問題
附錄
附錄A 軟件企業Java筆試真題1
附錄B 軟件企業Java筆試真題2
附錄C 軟件企業Java筆試真題3
附錄D 求職有用網站及QQ群一覽表
網路書店
類別
折扣
價格
-
新書87折$255