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

雪竹的天空

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 ) 閱讀(548) 評論(0)  編輯 收藏 引用

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導航: 博客園   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>
            亚洲国产91| 亚洲二区在线视频| 巨乳诱惑日韩免费av| 久久久精品999| 最近看过的日韩成人| 亚洲美女视频在线免费观看| 国产精品户外野外| 久久精品一区二区国产| 嫩草伊人久久精品少妇av杨幂| 夜夜爽99久久国产综合精品女不卡| 一区二区欧美日韩| 国产综合香蕉五月婷在线| 亚洲电影在线观看| 国产精品国产亚洲精品看不卡15| 久久在线91| 欧美日韩成人免费| 欧美在线日韩精品| 男女精品视频| 性久久久久久| 欧美ed2k| 欧美亚洲日本网站| 欧美ab在线视频| 亚洲免费影院| 久久亚洲国产成人| 亚洲影院在线观看| 久久久久天天天天| 亚洲午夜一区二区| 久久久最新网址| 亚洲一区二区三区精品视频| 久久精品国产99国产精品澳门| 在线亚洲高清视频| 久久精品午夜| 亚洲影视中文字幕| 久久综合网络一区二区| 午夜激情亚洲| 欧美成人黄色小视频| 欧美一级成年大片在线观看| 蜜桃av综合| 欧美在线国产| 欧美连裤袜在线视频| 久久夜色精品国产欧美乱| 欧美日韩另类一区| 免费的成人av| 国产乱码精品1区2区3区| 亚洲国产精品久久91精品| 国产欧美日韩综合一区在线观看| 亚洲国产精品高清久久久| 国产一区999| a4yy欧美一区二区三区| 亚洲电影免费观看高清| 亚洲欧美国产精品桃花| 一本到12不卡视频在线dvd| 久久精品国产免费看久久精品| 亚洲一区成人| 欧美成人情趣视频| 久久婷婷蜜乳一本欲蜜臀| 国产精品大片wwwwww| 亚洲盗摄视频| 永久免费精品影视网站| 亚洲欧美国产毛片在线| 亚洲无限乱码一二三四麻| 欧美国产第二页| 美女黄网久久| 国产一级久久| 亚洲综合色网站| 亚洲一区二区在线免费观看| 欧美国产日韩一区二区| 你懂的网址国产 欧美| 国产三级欧美三级日产三级99| 亚洲视频每日更新| 夜夜嗨av一区二区三区网页| 久久一二三区| 久久人人精品| 国产在线视频欧美| 午夜精品区一区二区三| 亚洲欧美日韩国产成人精品影院| 欧美日韩福利视频| 亚洲第一精品夜夜躁人人爽 | 日韩一级成人av| 亚洲精品美女91| 乱中年女人伦av一区二区| 久久只精品国产| 国产亚洲网站| 欧美亚洲免费电影| 欧美中文字幕不卡| 国产精品午夜在线观看| 亚洲午夜在线| 亚洲欧美国产精品va在线观看 | 国产老肥熟一区二区三区| 一区二区三区精品国产| 一区二区毛片| 欧美另类变人与禽xxxxx| 欧美国产激情二区三区| 亚洲国产成人av好男人在线观看| 久久久久88色偷偷免费| 老司机67194精品线观看| 伊人久久男人天堂| 久久婷婷国产综合尤物精品| 美女国内精品自产拍在线播放| 悠悠资源网亚洲青| 久久欧美中文字幕| 欧美高清视频一区| 亚洲人成网站精品片在线观看| 欧美成人视屏| 亚洲人成高清| 这里只有精品视频在线| 欧美午夜视频在线| 亚洲在线免费| 久久久精品国产免费观看同学| 国产亚洲午夜高清国产拍精品| 久久精品国产亚洲精品| 米奇777在线欧美播放| 亚洲国产综合91精品麻豆| 欧美成人性生活| 亚洲精品久久视频| 亚洲在线不卡| 国产三区精品| 久久天天躁狠狠躁夜夜av| 欧美激情亚洲另类| 一区二区高清视频| 国产精品毛片大码女人| 性做久久久久久| 免费欧美高清视频| 亚洲免费成人av| 国产精品hd| 欧美一级久久久久久久大片| 欧美r片在线| 一区二区三区四区蜜桃| 国产精品美女主播在线观看纯欲| 欧美一区二区大片| 欧美国产视频在线| 中文一区二区在线观看| 国产精品一香蕉国产线看观看 | 欧美在线视频不卡| 欧美福利影院| 中文欧美日韩| 国产午夜亚洲精品不卡| 美女日韩在线中文字幕| 一本色道久久88精品综合| 欧美在线影院在线视频| 亚洲二区视频| 欧美视频中文字幕| 久久av一区二区三区| 亚洲国产精品999| 亚洲欧美一区在线| 1024精品一区二区三区| 欧美三级在线| 久久精品亚洲国产奇米99| 亚洲人成亚洲人成在线观看图片| 先锋影音国产精品| 在线视频国内自拍亚洲视频| 欧美日韩综合不卡| 久久精品99久久香蕉国产色戒| 亚洲区一区二| 欧美中文字幕视频在线观看| 亚洲人在线视频| 国产精品尤物| 欧美精品二区三区四区免费看视频| 亚洲一区亚洲| 亚洲国产精品毛片| 久久精品日产第一区二区三区| 亚洲精品一区二区网址| 国产日本精品| 欧美精品在线免费观看| 久久精品国产99| 一区二区三区高清不卡| 久久全国免费视频| 亚洲欧美激情在线视频| 亚洲激情校园春色| 国产日韩欧美| 欧美日韩在线电影| 毛片一区二区三区| 小处雏高清一区二区三区| 亚洲精品国偷自产在线99热| 久久天天狠狠| 亚洲欧美另类在线观看| 亚洲人妖在线| 精品成人免费| 国产精品免费看| 欧美精品激情| 久久中文字幕一区| 小黄鸭精品密入口导航| 亚洲麻豆一区| 欧美好骚综合网| 久久亚洲影院| 久久国产欧美日韩精品| 国产精品99久久不卡二区| 亚洲国产精品精华液2区45| 国产欧美日韩亚州综合| 欧美视频在线观看视频极品| 欧美成人视屏| 久久综合久久久久88| 欧美一区二区三区四区高清| 一区二区三区免费网站| 亚洲精品美女在线观看播放| 欧美成人按摩| 久久欧美肥婆一二区| 欧美中文在线免费| 先锋a资源在线看亚洲| 亚洲一区亚洲二区|