国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

首頁 Java Java面試題 java面試中常見的數(shù)組題目匯總(二)

java面試中常見的數(shù)組題目匯總(二)

Nov 09, 2020 pm 03:27 PM
java 數(shù)組 面試

java面試中常見的數(shù)組題目匯總(二)

1、斐波那契數(shù)列

【題目】

大家都知道斐波那契數(shù)列,現(xiàn)在要求輸入一個整數(shù) n,請你輸出斐波那契數(shù)列的第 n 項(從 0 開始,第 0 項為 0)。

(視頻教程推薦:java課程

【代碼】

package swear2offer.array;


public class FeiBoNaQi {

    /**
     * 大家都知道斐波那契數(shù)列,現(xiàn)在要求輸入一個整數(shù) n,
     * 請你輸出斐波那契數(shù)列的第 n 項(從 0 開始,第 0 項為 0)。
     * 0,1,1,2,3,5
     * n<=39
     * */
    public int Fibonacci(int n) {
        if (n == 0) return 0;

        if (n == 1 || n== 2) return 1;

        return Fibonacci(n-1) + Fibonacci(n-2);
    }

    /**
     * 非遞歸方式,遞歸的數(shù)據(jù)結(jié)構(gòu)使用的棧,那就是使用棧的方式
     * */
    public int NoRecursive(int n) {
        if (n>2) {
            int[] a = new int[n+1];
            a[0] = 0;
            a[1] = 1;
            a[2] = 1;

            for (int i=3; i<=n; i++) {
                a[i] = a[i-1] + a[i-2];
            }

            return a[n];
        } else {
            if (n == 0) return 0;
            else return 1;
        }
    }

    public static void main(String[] args) {
        System.out.println(new FeiBoNaQi().Fibonacci(39));
        System.out.println(new FeiBoNaQi().Fibonacci(39));
    }
}

2、矩形覆蓋

【題目】

我們可以用 21 的小矩形橫著或者豎著去覆蓋更大的矩形。請問用 n 個 21 的小矩形無重疊地覆蓋一個 2*n 的大矩形,總共有多少種方法?

比如 n=3 時,2*3 的矩形塊有 3 種覆蓋方法:

12711bde10f197c3e9af47c34b0cc46.png

代碼:

package swear2offer.array;

public class Rectangle {

    /**
     * f[0] = 0;
     * f[1] = 1;
     * f[2] = 2;
     * f[3] = 3;
     * f[4] = 5;
     * f[5] = 8;
     * f[n] = f[n-1] + f[n-2]
     * */

    public int RectCover(int target) {

        if (target < 4) return target;

        int[] f = new int[target + 1];
        int i;
        for (i=0; i<4; i++) f[i] = i;

        for (i=4; i<=target; i++) {
            f[i] = f[i-1] + f[i-2];
        }

        return f[target];
    }



    public static void main(String[] args) {
        System.out.println(new Rectangle().RectCover(5));
    }
}

【思考】

最直白的結(jié)題方式就是找規(guī)律,從總結(jié)的規(guī)律可以看出這是斐波那契數(shù)列的實現(xiàn)方式;另一種就是根據(jù)題意來解答,求n的方法,這類問題很容易想到是從n-1來求解,而第一個塊是橫(f[n-2])是豎(f[n-1]),分別對應(yīng)不同的情況

(更多相關(guān)面試題推薦:java面試題及答案

3、二進制中 1 的個數(shù)

【題目】

輸入一個整數(shù),輸出該數(shù)二進制表示中 1 的個數(shù)。其中負數(shù)用補碼表示。

【代碼】

package swear2offer.array;

public class Binary {

    /**
     * 輸入一個整數(shù),輸出該數(shù)二進制表示中 1 的個數(shù)。其中負數(shù)用補碼表示。
     * */
    public int NumberOf1(int n) {
        int count;
        count = 0;

        while(n != 0) {
            n = n & (n-1);// 與操作就是二進制的操作,適用原碼和補碼
            count ++;
        }

        return count;
    }
}

【思考】

負數(shù)的反碼: 符號位不變,其余各位按位取反負數(shù)的補碼:在其反碼的基礎(chǔ)上+1

如果一個整數(shù)不為 0,那么這個整數(shù)至少有一位是 1。如果我們把這個整數(shù)減 1,那么原來處在整數(shù)最右邊的 1 就會變?yōu)?0,原來在 1 后面的所有的 0 都會變成 1 (如果最右邊的 1 后面還有 0 的話)。其余所有位將不會受到影響。

舉個例子:一個二進制數(shù) 1100,從右邊數(shù)起第三位是處于最右邊的一個 1。減去 1 后,第三位變成 0,它后面的兩位 0 變成了 1,而前面的 1 保持不變,因此得到的結(jié)果是 1011. 我們發(fā)現(xiàn)減 1 的結(jié)果是把最右邊的一個 1 開始的所有位都取反了。這個時候如果我們再把原來的整數(shù)和減去 1 之后的結(jié)果做與運算,從原來整數(shù)最右邊一個 1 那一位開始所有位都會變成 0。如 1100&1011=1000. 也就是說,把一個整數(shù)減去 1,再和原整數(shù)做與運算,會把該整數(shù)最右邊一個 1 變成 0. 那么一個整數(shù)的二進制有多少個 1,就可以進行多少次這樣的操作。

4、數(shù)值的整數(shù)次方

【題目】

給定一個 double 類型的浮點數(shù) base 和 int 類型的整數(shù) exponent。求 base 的 exponent 次方。
保證 base 和 exponent 不同時為 0

【代碼】

package swear2offer.array;

public class Power {

    public double Power(double base, int exponent) {

        if (base == 0) return 0;
        if (exponent == 0) return 1;

        int count;
        boolean flag;
        double temp;

        count = 1;
        temp = base;
        flag = true;// 標記正負

        if (exponent < 0){
            exponent = -exponent;
            flag = false;
        }

        while (count < exponent) {
            base *= temp;
            count ++;
        }

        if (flag) {
            return base;
        } else {
            return 1/base;
        }

    }

    public static void main(String[] args) {
        System.out.println(new Power().Power(2,-3));
    }

}

【思考】

本題難度并不大,算法也不是很復(fù)雜,但是邊邊角角很容易遺漏,

第一點就是exponent的正負,很容易就漏掉負數(shù)的情況

其次,base==0和exponent==0的情況是不一樣的

最后,base累乘的時候,是不能用本身的,因為base是不斷變大的。

5、調(diào)整數(shù)組順序使奇數(shù)位于偶數(shù)前面

【題目】

輸入一個整數(shù)數(shù)組,實現(xiàn)一個函數(shù)來調(diào)整該數(shù)組中數(shù)字的順序,使得所有的奇數(shù)位于數(shù)組的前半部分,所有的偶數(shù)位于數(shù)組的后半部分,并保證奇數(shù)和奇數(shù),偶數(shù)和偶數(shù)之間的相對位置不變。

【代碼】

package swear2offer.array;

import java.util.Arrays;

public class OddEven {

    /**
     * 輸入一個整數(shù)數(shù)組,實現(xiàn)一個函數(shù)來調(diào)整該數(shù)組中數(shù)字的順序,
     * 使得所有的奇數(shù)位于數(shù)組的前半部分,所有的偶數(shù)位于數(shù)組的后半部分,
     * 并保證奇數(shù)和奇數(shù),偶數(shù)和偶數(shù)之間的相對位置不變。
     *
     * 時空復(fù)雜度較高的算法:
     * 新建一個數(shù)組b,用來保存奇數(shù),在重新變量一次,保存偶數(shù)
     * 時空復(fù)雜度0(n)
     * */
    public void reOrderArray1(int [] array) {
        int n,i,j;
        n = array.length;

        int[] b = new int[n];

        j = 0;// 用來保存數(shù)組B的下標
        for (i=0; i<n; i++) {
            if (array[i]%2 != 0) {
                b[j] = array[i];
                j ++;
            }
        }
        for (i=0; i<n; i++) {
            if (array[i]%2 == 0){
                b[j] = array[i];
                j++;
            }
        }

        for (i=0; i<n; i++) {
            array[i] = b[i];
        }
    }

    /**
     * 采用的冒泡交換以及快速排序的思想:
     * 設(shè)定兩個游標,游標分別用來標記奇數(shù)和偶數(shù)的下標,然后交換二者
     * 注意交換二者是無法保證順序的,交換的ij之間還有進行平移。
     * */
    public void reOrderArray(int [] array) {

        int n,i,j,temp,p;

        n = array.length;
        i = 0;
        j = 0;
        while (i<n && j<n) {
            // i標記偶數(shù)下標
            while (i<n) {
                if (array[i]%2 ==0){
                    break;
                } else {
                    i++;
                }
            }
            j = i;
            // j標記奇數(shù)下標
            while (j<n) {
                if (array[j]%2 !=0){
                    break;
                } else {
                    j++;
                }
            }
            if (i<n && j<n) {
                // 此時ij已經(jīng)在遇到的第一個偶數(shù)和奇數(shù)停下,把ij之間的內(nèi)容平移
                temp = array[j];
                for (p=j; p>i; p--) {
                    array[p] = array[p-1];
                }
                array[i] = temp;
                // 此時把i,j標記到 未交換前的偶數(shù)位置的下一個
                i ++;
                j = i;
            }
        }
    }

    public static void main(String[] args) {
        int[] a = {1,4,6,3,2,5,8};
        int[] b = {2,4,6,1,3,5,7};
        new OddEven().reOrderArray(b);
        System.out.println(Arrays.toString(b));
    }
}

【思考】

顯然,創(chuàng)建新數(shù)組的方式,是一種取巧的方式,題目要求是需要在本數(shù)組上進行操作,第二種方式就是采用在本數(shù)組上進行操作的,而這種雙游標遞進的方式跟快速排序的思想很接近。

相關(guān)推薦:java入門

以上是java面試中常見的數(shù)組題目匯總(二)的詳細內(nèi)容。更多信息請關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻,版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機

Video Face Swap

Video Face Swap

使用我們完全免費的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強大的PHP集成開發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺化網(wǎng)頁開發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級代碼編輯軟件(SublimeText3)

如何在Java的地圖上迭代? 如何在Java的地圖上迭代? Jul 13, 2025 am 02:54 AM

遍歷Java中的Map有三種常用方法:1.使用entrySet同時獲取鍵和值,適用于大多數(shù)場景;2.使用keySet或values分別遍歷鍵或值;3.使用Java8的forEach簡化代碼結(jié)構(gòu)。entrySet返回包含所有鍵值對的Set集合,每次循環(huán)獲取Map.Entry對象,適合頻繁訪問鍵和值的情況;若只需鍵或值,可分別調(diào)用keySet()或values(),也可在遍歷鍵時通過map.get(key)獲取值;Java8中可通過Lambda表達式使用forEach((key,value)-&gt

Java中的可比較與比較器 Java中的可比較與比較器 Jul 13, 2025 am 02:31 AM

在Java中,Comparable用于類內(nèi)部定義默認排序規(guī)則,Comparator用于外部靈活定義多種排序邏輯。1.Comparable是類自身實現(xiàn)的接口,通過重寫compareTo()方法定義自然順序,適用于類有固定、最常用的排序方式,如String或Integer。2.Comparator是外部定義的函數(shù)式接口,通過compare()方法實現(xiàn),適合同一類需要多種排序方式、無法修改類源碼或排序邏輯經(jīng)常變化的情況。兩者區(qū)別在于Comparable只能定義一種排序邏輯且需修改類本身,而Compar

如何處理Java中的字符編碼問題? 如何處理Java中的字符編碼問題? Jul 13, 2025 am 02:46 AM

處理Java中的字符編碼問題,關(guān)鍵是在每一步都明確指定使用的編碼。1.讀寫文本時始終指定編碼,使用InputStreamReader和OutputStreamWriter并傳入明確的字符集,避免依賴系統(tǒng)默認編碼。2.在網(wǎng)絡(luò)邊界處理字符串時確保兩端一致,設(shè)置正確的Content-Type頭并用庫顯式指定編碼。3.謹慎使用String.getBytes()和newString(byte[]),應(yīng)始終手動指定StandardCharsets.UTF_8以避免平臺差異導(dǎo)致的數(shù)據(jù)損壞。總之,通過在每個階段

JavaScript數(shù)據(jù)類型:原始與參考 JavaScript數(shù)據(jù)類型:原始與參考 Jul 13, 2025 am 02:43 AM

JavaScript的數(shù)據(jù)類型分為原始類型和引用類型。原始類型包括string、number、boolean、null、undefined和symbol,其值不可變且賦值時復(fù)制副本,因此互不影響;引用類型如對象、數(shù)組和函數(shù)存儲的是內(nèi)存地址,指向同一對象的變量會相互影響。判斷類型可用typeof和instanceof,但需注意typeofnull的歷史問題。理解這兩類差異有助于編寫更穩(wěn)定可靠的代碼。

Hashmap在Java內(nèi)部如何工作? Hashmap在Java內(nèi)部如何工作? Jul 15, 2025 am 03:10 AM

HashMap在Java中通過哈希表實現(xiàn)鍵值對存儲,其核心在于快速定位數(shù)據(jù)位置。1.首先使用鍵的hashCode()方法生成哈希值,并通過位運算轉(zhuǎn)換為數(shù)組索引;2.不同對象可能產(chǎn)生相同哈希值,導(dǎo)致沖突,此時以鏈表形式掛載節(jié)點,JDK8后鏈表過長(默認長度8)則轉(zhuǎn)為紅黑樹提升效率;3.使用自定義類作鍵時必須重寫equals()和hashCode()方法;4.HashMap動態(tài)擴容,當(dāng)元素數(shù)超過容量乘以負載因子(默認0.75)時,擴容并重新哈希;5.HashMap非線程安全,多線程下應(yīng)使用Concu

Java中的'靜態(tài)”關(guān)鍵字是什么? Java中的'靜態(tài)”關(guān)鍵字是什么? Jul 13, 2025 am 02:51 AM

InJava,thestatickeywordmeansamemberbelongstotheclassitself,nottoinstances.Staticvariablesaresharedacrossallinstancesandaccessedwithoutobjectcreation,usefulforglobaltrackingorconstants.Staticmethodsoperateattheclasslevel,cannotaccessnon-staticmembers,

在C中使用std :: Chrono 在C中使用std :: Chrono Jul 15, 2025 am 01:30 AM

std::chrono在C 中用于處理時間,包括獲取當(dāng)前時間、測量執(zhí)行時間、操作時間點與持續(xù)時間及格式化解析時間。1.獲取當(dāng)前時間使用std::chrono::system_clock::now(),可轉(zhuǎn)換為可讀字符串但系統(tǒng)時鐘可能不單調(diào);2.測量執(zhí)行時間應(yīng)使用std::chrono::steady_clock以確保單調(diào)性,并通過duration_cast轉(zhuǎn)換為毫秒、秒等單位;3.時間點(time_point)和持續(xù)時間(duration)可相互操作,但需注意單位兼容性和時鐘紀元(epoch)

如何檢查數(shù)組是否在JavaScript中包含一個值 如何檢查數(shù)組是否在JavaScript中包含一個值 Jul 13, 2025 am 02:16 AM

在JavaScript中檢查數(shù)組是否包含某個值,最常用方法是includes(),它返回布爾值,語法為array.includes(valueToFind),例如fruits.includes('banana')返回true;若需兼容舊環(huán)境,則使用indexOf(),如numbers.indexOf(20)!==-1返回true;對于對象或復(fù)雜數(shù)據(jù),應(yīng)使用some()方法進行深度比較,如users.some(user=>user.id===1)返回true。

See all articles