有n个人在排队买票,队伍的位置为1到n。

给你一个数组a[i], 其中第i个人想要买a[i]张票。

每一秒,位于队列头的人一次可以买一张票。如果他这次买完了所有他需要的票,他就会离开否则,它会来到队伍末尾继续排队。

现在给出所有人需要的票数,需要你求出每个人买完票的时间。(第一个人买完第一张票算作第一秒)。

输入格式

第一行一个整数n。

接下来一行一个长度为n的字符串s(就是输入n个数字)。

输出格式

输出n个数,第i个数表示第i个人买完票的时间。

样例输入

4
3 4 2 1

样例输出

8 10 7 4

数据规模

对于所有数据,保证n≤1000, 1≤a[i]≤1000。

答案

#include <iostream>
#include <cstdio>
using namespace std;

const int N = 1e6+5;                    //由题意可得最多1000个人,每个人最多进队1000次,那么队列至少需要开1e6这么大
int Queue[N], front=1, rear=0;
int count[1005], Time[1005];            //count记录每个人还需要多少票,Time记录需要的时间

int main(){
	
	int n;
	scanf("%d", &n);
	for(int i=1; i<=n; i++){
		scanf("%d", &count[i]);        //每个人初始的买票数量
		Queue[++rear] = i;             //初始的买票顺序来依次进队
	}
		
	
	while(front <= rear){            //当front>rear队列为空,即所有人都买完票后就终止循环
		
		count[Queue[front]]--;       //买1张票就减1,队列中的是有那些人还需要买票
		
		if(count[Queue[front]] == 0)
			Time[Queue[front]] = front;    //此时的front就是该人买完票所需要的总时间
		else
			Queue[++rear] = Queue[front];    //没买完票就重新进队
		
		front++;           //该下一个人买票了
	}
		
	for(int i=1; i<=n; i++)
		printf("%d ", Time[i]);
	
	return 0;
}

 

Logo

魔乐社区(Modelers.cn) 是一个中立、公益的人工智能社区,提供人工智能工具、模型、数据的托管、展示与应用协同服务,为人工智能开发及爱好者搭建开放的学习交流平台。社区通过理事会方式运作,由全产业链共同建设、共同运营、共同享有,推动国产AI生态繁荣发展。

更多推荐