您好,登錄后才能下訂單哦!
今天就跟大家聊聊有關使用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怎么每隔兩個數刪掉一個數有進一步的了解嗎?如果還想了解更多知識或者相關內容,請關注億速云行業資訊頻道,感謝大家的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。