青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

雪竹的天空

theorix

  C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
  34 隨筆 :: 0 文章 :: 20 評論 :: 0 Trackbacks
Robotic Sort

Time limit: 2 Seconds   Memory limit: 32768K  
Total Submit: 12   Accepted Submit: 4  

Somewhere deep in the Czech Technical University buildings, there are laboratories for examining mechanical and electrical properties of various materials. In one of yesterday's presentations, you have seen how was one of the laboratories changed into a new multimedia lab. But there are still others, serving to their original purposes.

In this task, you are to write software for a robot that handles samples in such a laboratory. Imagine there are material samples lined up on a running belt. The samples have different heights, which may cause troubles to the next processing unit. To eliminate such troubles, we need to sort the samples by their height into the ascending order.

Reordering is done by a mechanical robot arm, which is able to pick up any number of consecutive samples and turn them round, such that their mutual order is reversed. In other words, one robot operation can reverse the order of samples on positions between A and B.

A possible way to sort the samples is to find the position of the smallest one (P1) and reverse the order between positions 1 and P1, which causes the smallest sample to become first. Then we find the second one on position P2 and reverse the order between 2 and P2. Then the third sample is located etc.

 

 

The picture shows a simple example of 6 samples. The smallest one is on the 4th position, therefore, the robot arm reverses the first 4 samples. The second smallest sample is the last one, so the next robot operation will reverse the order of five samples on positions 2 - 6. The third step will be to reverse the samples 3 - 4 etc.

Your task is to find the correct sequence of reversal operations that will sort the samples using the above algorithm. If there are more samples with the same height, their mutual order must be preserved: the one that was given first in the initial order must be placed before the others in the final order too.

Input

The input consists of several scenarios. Each scenario is described by two lines. The first line contains one integer number N, the number of samples, 1 <= N <= 100 000. The second line lists exactly N space-separated positive integers, they specify the heights of individual samples and their initial order.

The last scenario is followed by a line containing zero.

Output

For each scenario, output one line with exactly N integers P1, P2, . . .PN, separated by a space. Each Pi must be an integer (1 <= Pi <= N) giving the position of the i-th sample just before the i-th reversal operation.

Note that if a sample is already on its correct position Pi, you should output the number Pi anyway, indicating that the "interval between Pi and Pi" (a single sample) should be reversed.

Sample Input

6
3 4 5 1 6 2
4
3 3 2 1
0

Sample Output

4 6 4 5 6 6
4 2 4 4

 


Problem Source: The 2007 ACM Central Europe Programming Contest

 

 


  1/*
  2* Sample solution to the Sort problem.
  3* Central Europe Regional Contest 2007.
  4*
  5* Zdenek Dvorak, 2007
  6*/

  7
  8#include <stdio.h>
  9#include <stdlib.h>
 10
 11#define MAXN 200000
 12static int n, input[MAXN], ipermut[MAXN], permut[MAXN];
 13
 14struct node
 15{
 16int reverse, size, present;
 17struct node *l, *r, *f;
 18}
;
 19
 20static struct node path_nodes[MAXN];
 21static void
 22dump_tree (struct node *t, int reverse)
 23{
 24struct node *l, *r;
 25
 26reverse ^= t->reverse;
 27
 28= reverse ? t->r : t->l;
 29= reverse ? t->l : t->r;
 30
 31if (l)
 32    dump_tree (l, reverse);
 33
 34if (t->present)
 35    printf ("%d ", (int) (t - path_nodes));
 36
 37if (r)
 38    dump_tree (r, reverse);
 39}

 40
 41static void
 42dump_path (void)
 43{
 44int i;
 45
 46printf ("\n");
 47for (i = 0; i < n; i++)
 48    if (!path_nodes[i].f)
 49      {
 50printf ("--- ");
 51dump_tree (&path_nodes[i], 0);
 52      }

 53
 54printf (" ---\n");
 55}

 56
 57static void
 58clean_reverse (struct node *tree)
 59{
 60struct node *t;
 61
 62if (!tree->reverse)
 63    return;
 64
 65= tree->l; tree->= tree->r; tree->= t;
 66if (tree->l)
 67    tree->l->reverse = !tree->l->reverse;
 68if (tree->r)
 69    tree->r->reverse = !tree->r->reverse;
 70tree->reverse = 0;
 71}

 72
 73static void
 74fix_size (struct node *t)
 75{
 76int lsize = t->? t->l->size : 0;
 77int rsize = t->? t->r->size : 0;
 78
 79t->size = lsize + rsize + t->present;
 80}

 81
 82static void
 83rotate (struct node *t, struct node *f)
 84{
 85struct node **ftlink, **alink, *a;
 86
 87if (f->== t)
 88    {
 89      ftlink = &f->r;
 90      alink = &t->l;
 91    }

 92else
 93    {
 94      ftlink = &f->l;
 95      alink = &t->r;
 96    }

 97
 98t->= f->f;
 99if (f->f)
100    {
101      if (f->f->== f)
102f->f->= t;
103      else
104f->f->= t;
105    }

106
107= *alink;
108*ftlink = a;
109if (a)
110    a->= f;
111
112*alink = f;
113f->= t;
114
115fix_size (f);
116fix_size (t);
117}

118
119static void
120zigzig (struct node *t, struct node *f, struct node *gf)
121{
122struct node **gfflink, **ftlink, **blink, **clink, *b, *c;
123if (gf->== f)
124    {
125      gfflink = &gf->r;
126      ftlink = &f->r;
127      blink = &f->l;
128      clink = &t->l;
129    }

130else
131    {
132      gfflink = &gf->l;
133      ftlink = &f->l;
134      blink = &f->r;
135      clink = &t->r;
136    }

137
138= *blink;
139= *clink;
140
141t->= gf->f;
142if (gf->f)
143    {
144      if (gf->f->== gf)
145gf->f->= t;
146      else
147gf->f->= t;
148    }

149
150*clink = f;
151f->= t;
152
153*blink = gf;
154gf->= f;
155
156*gfflink = b;
157if (b)
158    b->= gf;
159
160*ftlink = c;
161if (c)
162    c->= f;
163
164fix_size (gf);
165fix_size (f);
166fix_size (t);
167}

168
169static void
170zigzag (struct node *t, struct node *f, struct node *gf)
171{
172struct node **gfflink, **ftlink, **blink, **clink, *b, *c;
173if (gf->== f)
174    {
175      gfflink = &gf->l;
176      ftlink = &f->r;
177      blink = &t->l;
178      clink = &t->r;
179    }

180else
181    {
182      gfflink = &gf->r;
183      ftlink = &f->l;
184      blink = &t->r;
185      clink = &t->l;
186    }

187
188= *blink;
189= *clink;
190
191t->= gf->f;
192if (gf->f)
193    {
194      if (gf->f->== gf)
195gf->f->= t;
196      else
197gf->f->= t;
198    }

199
200*clink = gf;
201gf->= t;
202
203*blink = f;
204f->= t;
205
206*gfflink = c;
207if (c)
208    c->= gf;
209
210*ftlink = b;
211if (b)
212    b->= f;
213
214fix_size (gf);
215fix_size (f);
216fix_size (t);
217}

218
219static void
220double_rotate (struct node *t, struct node *f, struct node *gf)
221{
222if ((gf->== f) == (f->== t))
223    zigzig (t, f, gf);
224else
225    zigzag (t, f, gf);
226}

227
228static void
229splay (struct node *t)
230{
231struct node *f, *gf;
232
233while (t->f)
234    {
235      f = t->f;
236
237      gf = f->f;
238      if (!gf)
239{
240   clean_reverse (f);
241   clean_reverse (t);
242   rotate (t, f);
243   return;
244}

245      clean_reverse (gf);
246      clean_reverse (f);
247      clean_reverse (t);
248
249      double_rotate (t, f, gf);
250    }

251
252clean_reverse (t);
253}

254
255static int
256rotfirst_and_delete (struct node *t)
257{
258int pos;
259
260splay (t);
261/*printf ("After splay: ");
262dump_path();
263printf ("\n");*/

264if (t->l)
265    {
266      t->l->reverse = !t->l->reverse;
267      pos = t->l->size;
268    }

269else
270    pos = 0;
271
272t->present = 0;
273t->size--;
274
275return pos;
276}

277
278static int
279cmp_input (const void *a, const void *b)
280{
281int va = *(int *) a;
282int vb = *(int *) b;
283
284if (input[va] != input[vb])
285    return input[va] - input[vb];
286
287return va - vb;
288}

289
290int
291main (void)
292{
293int i;
294
295while (1)
296    {
297      scanf ("%d"&n);
298      if (!n)
299return 0;
300
301      for (i = 0; i < n; i++)
302scanf ("%d"&input[i]);
303
304      for (i = 0; i < n; i++)
305ipermut[i] = i;
306
307      qsort (ipermut, n, sizeof (int), cmp_input);
308
309      for (i = 0; i < n; i++)
310permut[ipermut[i]] = i;
311
312/*      for (i = 0; i < n; i++)
313printf ("%d ", permut[i]);
314      printf ("\n");*/

315      for (i = 0; i < n; i++)
316{
317   path_nodes[permut[i]].reverse = 0;
318   path_nodes[permut[i]].size = i + 1;
319   path_nodes[permut[i]].present = 1;
320   path_nodes[permut[i]].l = i > 0 ? &path_nodes[permut[i-1]] : NULL;
321   path_nodes[permut[i]].r = NULL;
322   path_nodes[permut[i]].f = i < n - 1 ? &path_nodes[permut[i+1]] : NULL;
323}

324
325      for (i = 0; i < n; i++)
326{
327   /*dump_path ();*/
328   printf ("%d%c", rotfirst_and_delete (&path_nodes[i]) + i + 1, i+1 < n ? ' ' : '\n');
329}

330    }

331}

332
posted on 2008-08-31 00:49 雪竹的天空( theorix ) 閱讀(537) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            欧美日韩一视频区二区| 亚洲伦伦在线| 最新热久久免费视频| 国产一区清纯| 黄色影院成人| ●精品国产综合乱码久久久久| 国产一区二区电影在线观看 | 欧美88av| 欧美亚洲免费电影| 亚洲区在线播放| 亚洲精品国产精品国自产观看| 亚洲欧洲一区二区三区久久| 欧美三区免费完整视频在线观看| 久久久91精品国产| 新片速递亚洲合集欧美合集| 日韩一区二区精品视频| 亚洲一区亚洲| 日韩亚洲欧美中文三级| 国产精品视频最多的网站| 国产亚洲毛片在线| 国产一区二区三区在线观看精品 | 欧美在线视屏| 欧美中文字幕不卡| 欧美jizz19性欧美| 亚洲理论电影网| 欧美一区日韩一区| 欧美巨乳波霸| 国产主播喷水一区二区| 99国产欧美久久久精品| 久久久久久精| 一本久久综合亚洲鲁鲁五月天| 午夜精品亚洲一区二区三区嫩草| 久久资源av| 国产精品美女久久久久久免费| 亚洲成在线观看| 日韩视频在线一区二区| 嫩草伊人久久精品少妇av杨幂| 欧美在线观看www| 亚洲欧洲在线一区| 好看的日韩av电影| 国产亚洲一级高清| 精品88久久久久88久久久| 韩日精品在线| 亚洲美女免费精品视频在线观看| 欧美日韩国产精品一卡| 亚洲狼人综合| 亚洲国产高清一区| 宅男噜噜噜66一区二区 | 久久成人精品| 亚洲国产成人在线| 久久免费偷拍视频| 久久久久久穴| 亚洲成人在线视频播放| 亚洲欧洲在线视频| 久久久国产一区二区| 亚洲视频一区在线观看| 久久国产综合精品| 国产精品成人av性教育| 亚洲精品乱码久久久久久蜜桃91| 一区二区三区视频观看| 亚洲第一页中文字幕| 一本色道**综合亚洲精品蜜桃冫| 久久精品欧美| 亚洲一区二区三区在线| 欧美日韩中文字幕日韩欧美| 亚洲美女性视频| 欧美激情免费观看| 老司机免费视频一区二区| 精品成人在线视频| 久久蜜桃资源一区二区老牛| 欧美中文字幕| 亚洲国产精品电影| 亚洲福利视频网| 欧美福利在线观看| 一本色道久久综合一区| 99精品视频免费在线观看| 欧美日韩中文字幕精品| 欧美一级大片在线观看| 亚洲欧美一区二区在线观看| 国产午夜一区二区三区| 久久综合给合| 久久婷婷国产麻豆91天堂| 在线观看欧美一区| 亚洲国产精品www| 欧美激情一区| 亚洲欧美日韩视频一区| 午夜在线成人av| 在线观看一区视频| 亚洲精选成人| 国内精品免费午夜毛片| 久久在线免费| 免费人成精品欧美精品| 亚洲影院污污.| 久久福利毛片| 一本久道综合久久精品| 亚洲欧美影院| 亚洲免费激情| 先锋影音网一区二区| 日韩视频免费| 欧美一级大片在线免费观看| 亚洲区一区二| 亚洲综合欧美日韩| 亚洲国产精品一区| 亚洲一区国产视频| 亚洲国产小视频在线观看| 一区二区三区免费观看| 亚洲国产欧美一区二区三区久久 | 亚洲天天影视| 亚洲国产mv| 亚洲国产欧美一区二区三区久久| 中国av一区| 久久精品国产v日韩v亚洲| 99成人在线| 久久久精品欧美丰满| 亚洲图片在线观看| 可以看av的网站久久看| 欧美一区二区黄| 欧美日韩成人激情| 欧美freesex交免费视频| 国产精品久久久久9999| 亚洲国产精品久久精品怡红院 | 亚洲免费影视第一页| 亚洲国产三级| 久久国产精品久久精品国产| 亚洲免费视频成人| 欧美日本精品| 亚洲国产精品久久久久秋霞不卡| 国产一区二区三区久久悠悠色av| 一区二区久久久久| 一本一本久久| 欧美电影专区| 欧美激情精品久久久久久蜜臀| 国产一区二区三区高清 | 久久久久国产一区二区三区| 午夜精品久久久久影视| 欧美精品在线播放| 亚洲欧洲精品一区二区| 亚洲国产成人久久综合| 久久久久国产精品人| 久久免费视频在线观看| 国产亚洲精品综合一区91| 午夜精品久久99蜜桃的功能介绍| 亚洲午夜精品在线| 国产精品国产三级国产专区53| 99re6热在线精品视频播放速度| 99精品国产福利在线观看免费| 欧美激情精品久久久| 亚洲黄色av| 日韩图片一区| 欧美午夜无遮挡| 亚洲欧美日本日韩| 久久久噜噜噜久久| 亚洲成色777777在线观看影院| 久久夜色精品国产欧美乱极品 | 一本色道久久综合亚洲精品不 | 欧美精品在线免费| 一本久道久久综合狠狠爱| 午夜精品一区二区三区在线视| 国产精品国产a级| 午夜精彩国产免费不卡不顿大片| 久久中文字幕一区| 一区二区欧美激情| 国产精品v欧美精品v日韩| 性欧美大战久久久久久久久| 久久亚洲一区二区| 亚洲精品在线观看免费| 欧美性事在线| 亚洲乱码国产乱码精品精98午夜| 亚洲欧洲精品天堂一级| 亚洲一区在线播放| 国产亚洲成人一区| 欧美成人午夜免费视在线看片 | 国产一区二区欧美| 免费日韩视频| 亚洲午夜精品17c| 久久精品国产99| 亚洲国产成人午夜在线一区| 欧美色欧美亚洲另类二区| 欧美一级在线视频| 91久久黄色| 久久久www成人免费无遮挡大片| 91久久综合亚洲鲁鲁五月天| 国产精品裸体一区二区三区| 久久一区二区三区四区| 一本综合久久| 欧美1区免费| 欧美一级淫片aaaaaaa视频| 亚洲大片免费看| 国产精品久久久久国产a级| 久久久中精品2020中文| 亚洲视频在线二区| 欧美激情精品久久久久| 久久精品国产v日韩v亚洲| 在线亚洲一区二区| 亚洲国产成人在线| 国产综合色一区二区三区| 国产精品高潮呻吟| 欧美日韩免费一区二区三区| 久久久久综合| 欧美一级免费视频|