91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

使用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

沙田区| 连南| 偏关县| 托克托县| 凤山县| 马关县| 冀州市| 许昌市| 本溪市| 大洼县| 棋牌| 吉木乃县| 陵川县| 三台县| 濮阳县| 伊吾县| 花莲市| 万荣县| 武定县| 丰城市| 石城县| 青阳县| 青铜峡市| 禄丰县| 嵊州市| 乐陵市| 雷州市| 抚松县| 鲁山县| 澎湖县| 朔州市| 文山县| 土默特左旗| 定西市| 神木县| 元氏县| 富平县| 六安市| 嵊泗县| 吴川市| 当阳市|