CodeForces 549G Happy Line

本博客探讨了如何通过货币交换使Berland居民在排队购买冰淇淋时保持幸福感。详细介绍了算法步骤,并通过示例代码展示了解决方案。
Happy Line
Time Limit:1000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I64u

Description

Do you like summer? Residents of Berland do. They especially love eating ice cream in the hot summer. So this summer day a large queue of n Berland residents lined up in front of the ice cream stall. We know that each of them has a certain amount of berland dollars with them. The residents of Berland are nice people, so each person agrees to swap places with the person right behind him for just 1 dollar. More formally, if person a stands just behind person b, then person a can pay person b 1 dollar, then a and b get swapped. Of course, if person a has zero dollars, he can not swap places with person b.

Residents of Berland are strange people. In particular, they get upset when there is someone with a strictly smaller sum of money in the line in front of them.

Can you help the residents of Berland form such order in the line so that they were all happy? A happy resident is the one who stands first in the line or the one in front of who another resident stands with not less number of dollars. Note that the people of Berland are people of honor and they agree to swap places only in the manner described above.

Input

The first line contains integer n (1 ≤ n ≤ 200 000) — the number of residents who stand in the line.

The second line contains n space-separated integers ai (0 ≤ ai ≤ 109), where ai is the number of Berland dollars of a man standing on the i-th position in the line. The positions are numbered starting from the end of the line.

Output

If it is impossible to make all the residents happy, print ":(" without the quotes. Otherwise, print in the single line n space-separated integers, the i-th of them must be equal to the number of money of the person on position i in the new line. If there are multiple answers, print any of them.

Sample Input

Input
2
11 8
Output
9 10 
Input
5
10 9 7 10 6
Output
:(
Input
3
12 3 3
Output
4 4 10 

Hint

In the first sample two residents should swap places, after that the first resident has 10 dollars and he is at the head of the line and the second resident will have 9 coins and he will be at the end of the line.

In the second sample it is impossible to achieve the desired result.

In the third sample the first person can swap with the second one, then they will have the following numbers of dollars: 4 11 3, then the second person (in the new line) swaps with the third one, and the resulting numbers of dollars will equal to: 4 4 10. In this line everybody will be happy.

 1 #include <stdio.h>
 2 #include <string.h>
 3 #include <algorithm>
 4 using namespace std;
 5 
 6 struct Node 
 7 {
 8     int v;
 9     int id;
10 }a[200005];
11 
12 bool cmp(Node x,Node y)
13 {
14     return (x.v+x.id)<(y.v+y.id);
15 }
16 
17 int main()
18 {
19     int n;
20     int i,j;
21     scanf("%d",&n);
22     for(i=1;i<=n;i++)
23     {
24         scanf("%d",&a[i].v);
25         a[i].id=i;
26     }
27     sort(a+1,a+n+1,cmp);
28     int flg=1;
29     for(i=1;i<=n;i++)
30     {
31         a[i].v=a[i].v-(i-a[i].id);
32         if(a[i].v<0 || (i>=2 && a[i].v<a[i-1].v))
33             flg=0;
34     }
35     if(flg==1)
36     {
37         printf("%d",a[1].v);
38         for(i=2;i<=n;i++)
39             printf(" %d",a[i].v);
40         printf("\n");
41     }
42     else
43     {
44         printf(":(\n");
45     }
46     return 0;
47 }
View Code

 

转载于:https://www.cnblogs.com/cyd308/p/4771555.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值