UVA-1610

这个题感觉好绕,最后绕出来了,发现uDebug里面的也有错??
直接暴力求解法就出来了,不用比较啥的。
如果用注释掉的“比较法”代码,估计错就错在是’A’到’Z’的序列,如果超过Z还要长度加一的。

#include<bits/stdc++.h>
using namespace std;

int main(void){
    int n;
    while(scanf("%d",&n)==1&&n!=0){
        string a[n+5];
        for(int i=0;i<n;i++){
            cin>>a[i];
        }
        sort(a,a+n);
        string lef=a[n/2-1];
        string rit=a[n/2];
        string ans;
        int pos = 0,flag=0,l=min(lef.size(),rit.size());
        while(1){
            for(int i=0;i<26;i++){
                string temp;
                temp=ans;
                temp+='A'+i;
                if(temp<rit&&temp>=lef){
                    flag=1;
                    ans=temp;
                    break;
                }
            }
            if(flag){
                break;
            }
            ans+=lef[pos++];
        }

//        while(pos<l){
//            if(pos==l-1){
//                if(rit.size()<lef.size()){
//                    if(rit[pos]-1>lef[pos]){
//                        ans+=lef[pos]+1;
//                    }
//                    else{
//                        ans+=lef[pos];
//                        if(++pos==lef.size()-1){
//                            ans+=lef[pos];
//                        }
//                        else{
//                            ans+=lef[pos]+1;
//                        }
//                        ans=lef;
//                    }
//                }
//                else{
//                    ans=lef;
//                }
//                break;
//            }
//            if(lef[pos]<rit[pos]){
//                ans+=lef[pos]+1;
//                break;
//            }
//            ans+=lef[pos];
//            pos++;
//        }
        cout<<ans<<endl;
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值