中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

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

峨眉山市| 蒙山县| 永胜县| 张家口市| 房产| 海口市| 沈丘县| 晋城| 教育| 邓州市| 弥渡县| SHOW| 航空| 巴彦县| 恩施市| 新兴县| 深水埗区| 翁源县| 麻栗坡县| 镇巴县| 台南县| 诏安县| 东阿县| 剑川县| 钟祥市| 石狮市| 焉耆| 远安县| 合川市| 冷水江市| 吐鲁番市| 武强县| 宜兰县| 绩溪县| 外汇| 中牟县| 密云县| 衡南县| 宁强县| 福泉市| 莫力|