亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

使用Java怎么每隔兩個數刪掉一個數

發布時間:2021-04-30 15:34:09 來源:億速云 閱讀:215 作者:Leah 欄目:開發技術

今天就跟大家聊聊有關使用Java怎么每隔兩個數刪掉一個數,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結了以下內容,希望大家根據這篇文章可以有所收獲。

Java可以用來干什么

Java主要應用于:1. web開發;2. Android開發;3. 客戶端開發;4. 網頁開發;5. 企業級應用開發;6. Java大數據開發;7.游戲開發等。

題目描述

有一個數組a[N]順序存放0~N-1,要求每隔兩個數刪掉一個數,到末尾時循環至開頭繼續進行,求最后一個被刪掉的數的原始下標位置。

以8個數(N=7)為例:{0,1,2,3,4,5,6,7},
0->1->2(刪除)->3->4->5(刪除)->6->7->0(刪除)
如此循環直到最后一個數被刪除。

輸入:
8

輸出:
6

解題思路

一看到這個題目,就想到了隊列的約瑟夫環的問題
此題思路:將兩個數字取出來放到隊列的后邊,刪掉第三個數字,如此循環,當隊列只剩一個數字的時候,刪掉它就是最后一個刪除的數字。

代碼如下

import java.util.LinkedList;
import java.util.Queue;
import java.util.Scanner;

public class Main1 {
    /**
     * 每日一題-隔兩個刪數問題
     * 類似于約瑟夫環問題
     * @param args
     */
    public static void main(String[] args){
        Scanner scanner = new Scanner(System.in);
        if(scanner.hasNext()) {
            int n = scanner.nextInt();
            Queue<Integer> queue = new LinkedList<>();
            for (int i = 0; i < n; i++) {
                queue.offer(i);//放進隊列中
            }
            while(queue.size()>1){
            //將兩個放到隊尾,再刪一個
                queue.offer(queue.poll());
                queue.offer(queue.poll());
                queue.poll();
            }
            System.out.println(queue.poll());
        }
    }
}

看完上述內容,你們對使用Java怎么每隔兩個數刪掉一個數有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

滁州市| 贵南县| 滦南县| 开鲁县| 汽车| 湟中县| 徐闻县| 连州市| 三门峡市| 克东县| 蒙自县| 阜新市| 石渠县| 慈溪市| 湛江市| 酉阳| 克山县| 如皋市| 桂东县| 丹寨县| 土默特左旗| 罗山县| 乃东县| 晋中市| 海丰县| 武宁县| 文安县| 江川县| 那曲县| 正镶白旗| 连云港市| 晴隆县| 辉县市| 舟山市| 乌拉特后旗| 新巴尔虎左旗| 松潘县| 波密县| 青浦区| 女性| 黄冈市|