-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path950.reveal-cards-in-increasing-order.cpp
107 lines (104 loc) · 2.79 KB
/
950.reveal-cards-in-increasing-order.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/*
* @lc app=leetcode id=950 lang=cpp
*
* [950] Reveal Cards In Increasing Order
*
* https://leetcode.com/problems/reveal-cards-in-increasing-order/description/
*
* algorithms
* Medium (71.36%)
* Total Accepted: 10.4K
* Total Submissions: 14.5K
* Testcase Example: '[17,13,11,2,3,5,7]'
*
* In a deck of cards, every card has a unique integer. You can order the deck
* in any order you want.
*
* Initially, all the cards start face down (unrevealed) in one deck.
*
* Now, you do the following steps repeatedly, until all cards are
* revealed:
*
*
* Take the top card of the deck, reveal it, and take it out of the deck.
* If there are still cards in the deck, put the next top card of the deck at
* the bottom of the deck.
* If there are still unrevealed cards, go back to step 1. Otherwise, stop.
*
*
* Return an ordering of the deck that would reveal the cards in increasing
* order.
*
* The first entry in the answer is considered to be the top of the deck.
*
*
*
*
* Example 1:
*
*
* Input: [17,13,11,2,3,5,7]
* Output: [2,13,3,11,5,17,7]
* Explanation:
* We get the deck in the order [17,13,11,2,3,5,7] (this order doesn't matter),
* and reorder it.
* After reordering, the deck starts as [2,13,3,11,5,17,7], where 2 is the top
* of the deck.
* We reveal 2, and move 13 to the bottom. The deck is now [3,11,5,17,7,13].
* We reveal 3, and move 11 to the bottom. The deck is now [5,17,7,13,11].
* We reveal 5, and move 17 to the bottom. The deck is now [7,13,11,17].
* We reveal 7, and move 13 to the bottom. The deck is now [11,17,13].
* We reveal 11, and move 17 to the bottom. The deck is now [13,17].
* We reveal 13, and move 17 to the bottom. The deck is now [17].
* We reveal 17.
* Since all the cards revealed are in increasing order, the answer is
* correct.
*
*
*
*
*
* Note:
*
*
* 1 <= A.length <= 1000
* 1 <= A[i] <= 10^6
* A[i] != A[j] for all i != j
*
*
*
*
*/
#include<bits/stdc++.h>
#include<deque>
using namespace std;
class Solution {
public:
vector<int> deckRevealedIncreasing(vector<int>& deck) {
deque<int> dq;
deque<int> order;
vector<int> res(deck.size());
sort(deck.begin(),deck.end());
for(int i=0;i<deck.size();i++){
dq.emplace_back(i);
}
while(1){
int top = dq.front();
order.emplace_front(top);
dq.pop_front();
if(dq.empty()) break;
dq.emplace_back(dq.front());
dq.pop_front();
}
for(int i=0;i<deck.size();i++)
res[i] = deck[order[i]];
return res;
}
};
int main(){
Solution sol;
vector<int> deck{17,13,11,2,3,5,7};
auto answer = sol.deckRevealedIncreasing(deck);
for(int i:answer)
cout << i << endl;
}