someone_lunatic_lyk_hell's blog

By someone_lunatic_lyk_hell, history, 3 months ago, In English

Hello Codeforces community,

I've been working on a problem involving queue dynamics and chair allocation, and I'm seeking your expertise to find an efficient solution that fits within tight constraints.

Problem Statement: Description: You are given a queue of n people, numbered from 1 to n. Each person i has an initial preferred chair number Pi, which is a positive integer. There is an infinite number of chairs, labelled with positive integers starting from 1.

The queue operates under the following rules: Queue Processing: People are processed in the order they appear in the queue.

Chair Allocation Process: When a person reaches the front of the queue, they attempt to sit on their current preferred chair Pi.

If the chair Pi is unoccupied: They sit on chair Pi and leave the queue.

If the chair Pi is already occupied: They are sent to the end of the queue and their preferred chair number increases by 1. They will attempt to sit on this new preferred chair when they reach the front of the queue again.

This process continues until all people have been allocated a chair.

Objective: Determine the chair number allocated to each person, in the order of their original positions in the queue (from person 1 to person n).

Input Format: The first line contains an integer n (1 <= n <= 10^5), the number of people in the queue. The second line contains n space-separated positive integers P1, P2, ..., Pn. (1 <= Pi <= n), where Pi is the initial preferred chair number of the i-th person.

Output: n space-separated integers, where the i-th integer represents the chair number allocated to the i-th person.

»
3 months ago, # |
  Vote: I like it 0 Vote: I do not like it

Auto comment: topic has been updated by someone_lunatic_lyk_hell (previous revision, new revision, compare).

»
3 months ago, # |
  Vote: I like it 0 Vote: I do not like it

You can solve this in $$$O(N)$$$ with a stack, maintaining it as you iterate through the chair numbers from $$$1$$$ to $$$2N - 1$$$. At chair number $$$i$$$, the stack would store the people who ever visit chair $$$i$$$, in order of the time of visit.

  • »
    »
    3 months ago, # ^ |
      Vote: I like it 0 Vote: I do not like it

    Can u please elaborate your approach a little bit more. I am struck in this problem from so long.

    • »
      »
      »
      2 months ago, # ^ |
        Vote: I like it 0 Vote: I do not like it

      Were you able to solve this problem? I recently came across this in a company coding test.

»
2 months ago, # |
Rev. 3   Vote: I like it 0 Vote: I do not like it

int main() { set<int>st; for(int i=1;i<=2e5;i++){ st.insert(i); } int t; cin>>t; while(t--){ int n; cin>>n; map<int,vector<int>>m; for(int i=0;i<n;i++){ int x; cin>>x; m[x].push_back(i); } vector<int>ans(n); auto it=--m.end(); while(true){ for(auto it1:(*it).second){ auto it2=st.lower_bound((*it).first); ans[it1]=*it2; st.erase(it2); } if(it==m.begin()){ break; } it--; } for(int i=0;i<n;i++){ st.insert(ans[i]); cout<<ans[i]<<" "; } cout<<endl; } }