poj3617
本文地址:https://www.cnblogs.com/maplefighting/p/9108493.html
题目名称:Best Cow Line
链接:http://poj.org/problem?id=3617
题意:有一个竞赛,FJ计划把他的原先牛的队列变成字典序最小的串。规则是依次把原先牛队列的头部或者尾部放到新串队列的尾部。
思路:贪心,开始想到我们每次把牛头部和尾部比较小的丢到新队列。然而这样如果头尾相同的话就要考虑接下去第二个字符的大小,依次类推。碰到哪边比较小的就得拿哪边的,相同就都可以。输出按每行 80 头输出 (注意!)。
代码如下:
1 #include<cstdio>
2 using namespace std;
3 char str[2005];
4 int main() {
5 int n;
6 scanf("%d", &n);
7 for(int i = 1; i <= n; ++i){
8 getchar();
9 scanf("%c", &str[i]);
10 }
11 int a = 1, b = n, ans = 0;
12 while(a <= b) {
13 bool left = false;
14 for(int i = 0; i <= (b - a) / 2; ++i) {
15 if(str[a + i] < str[b - i]) {
16 left = true; break;
17 }
18 else if(str[a + i] > str[b - i]) {
19 left = false; break;
20 }
21 }
22 if(left) putchar(str[a++]);
23 else putchar(str[b--]);
24 ans++;
25 if(ans % 80 == 0)
26 puts("");
27 }
28 puts("");
29 return 0;
30 }
本文版权归作者本人所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利.