标签:优先队列
链接:http://codeforces.com/contest/128/problem/B
One day in the IT lesson Anna and Maria learned about the lexicographic order.
String x is lexicographically less than string y, if either x is a prefix of y (and x?≠?y), or there exists such i (1?≤?i?≤?min(|x|,?|y|)), thatxi?<?yi, and for any j (1?≤?j?<?i) xj?=?yj. Here |a| denotes the length of the string a. The lexicographic comparison of strings is implemented by operator < in modern programming languages??.
The teacher gave Anna and Maria homework. She gave them a string of length n. They should write out all substrings of the given string, including the whole initial string, and the equal substrings (for example, one should write out the following substrings from the string "aab": "a", "a", "aa", "ab", "aab", "b"). The resulting strings should be sorted in the lexicographical order. The cunning teacher doesn‘t want to check all these strings. That‘s why she said to find only the k-th string from the list. Help Anna and Maria do the homework.
The first line contains a non-empty string that only consists of small Latin letters ("a"-"z"), whose length does not exceed 105. The second line contains the only integer k (1?≤?k?≤?105).
Print the string Anna and Maria need — the k-th (in the lexicographical order) substring of the given string. If the total number of substrings is less than k, print a string saying "No such line." (without the quotes).
aa 2
a
abc 5
bc
abab 7
b
In the second sample before string "bc" follow strings "a", "ab", "abc", "b".
题意:字典序排序子串,找出子串中的第n大。
做法:因为最多让你找第100000大,所以可以用优先队列。先放入单个的。然后不断取出最小的,然后添加一个 其后面的字母,然后再放回队列。 队列里len个串,最多放n次,所以复杂度 log(len)*n。
但是vs2010 的优先队列好像很慢。 另外一题有次也用到优先队列,vs2010跑好几分钟跑不出来的数据,CB可以秒跑。 所以这题不要交vs2010,不然会超时。
#pragma comment(linker, "/STACK:102400000,102400000") #include <stdio.h> #include <stdlib.h> #include <string.h> #include <limits.h> #include <malloc.h> #include <ctype.h> #include <math.h> #include <string> #include <iostream> #include <algorithm> using namespace std; #include <stack> #include <queue> #include <vector> #include <deque> #include <set> #include <map> struct point { int id; string ss; bool operator <(const point &b) const { return ss>b.ss; } }; char str[100010]; int main() { int n; scanf("%s %d",str,&n); //n>>str>>n; priority_queue<point>q; int len=strlen(str); for(int i=0;str[i];i++) { point tem; tem.ss=""; tem.ss=str[i]; tem.id=i; q.push(tem); } int id=0; point ans; while(!q.empty()) { point tem=q.top(); q.pop(); id++; if(id==n) { ans=tem; break; } tem.id++; if(tem.id<len) { tem.ss+=str[tem.id]; q.push(tem); } } if(id!=n) { puts("No such line."); } else { cout<<ans.ss<<endl; } return 0; }
版权声明:本文为博主原创文章,未经博主允许不得转载。
标签:优先队列
原文地址:http://blog.csdn.net/u013532224/article/details/48132397