E. A Simple Task
Problem's Link: http://codeforces.com/problemset/problem/558/E
Problem's Link: http://codeforces.com/problemset/problem/558/E
Mean:
给定一个字符串,有q次操作,每次操作将(l,r)内的字符升序或降序排列,输出q次操作后的字符串。
analyse:
基本思想是计数排序。
所谓计数排序,是对一个元素分布较集中的数字集群进行排序的算法,时间复杂度为O(n),但使用条件很苛刻。首先对n个数扫一遍,映射出每个数字出现的次数,然后再O(n)扫一遍处理出:对于数字ai,有多少个数字在ai前面。有了这个信息,我们就可以在O(1)的时间内确定出排序后ai所在的位置。
解题思路:
对于每个Query,我们先统计出(l,r)区间内每个字母出现的次数,然后分类来排序(非升或非降)。这个更新操作就相当于:
for(int j=x; j<=y; j++) cnt[s[j] - 'a']++; ind = 0; for(int j=x; j<=y; j++) { while(cnt[ind] == 0) ind++; s[j] = ind + 'a'; cnt[ind]--; }