为了账号安全,请及时绑定邮箱和手机立即绑定

Uva 140 Bandwidth

标签:
C++

#include<bits/stdc++.h>

using namespace std;

int id[30];

char letter[10];

int main(){

    //数据输入

    char input[1000];

    while(scanf("%s",input) == 1 && input[0]!='#'){

        int n=0;

        for(char tmp='A';tmp<='Z';tmp++)

            if(strchr(input,tmp)!=NULL){

                id[tmp-'A']=n++;

                letter[id[tmp-'A']]=tmp;

            }

        int len=strlen(input),p=0,q=0;

        vector<int>u,v;

        while(true){

            while(p < len && input[p] !=':') p++;

            if(p==len) break;

            while(q < len && input[q] != ';') q++;

            for(int i=p+1;i<q;i++){

                u.push_back(id[input[p-1]-'A']);

                v.push_back(id[input[i]-'A']);

            }

            p++;q++;

        }

    //处理

        int P[10],bestP[10],pos[10],ans=n;

        for(int i=0;i<n;i++) P[i]=i;

        do{

            for(int i=0;i<n;i++) pos[P[i]]=i;

            int wid=0;

            for(int i=0;i<u.size();i++) wid=max(wid,abs(pos[u[i]]-pos[v[i]]));

            if(wid<ans) {ans=wid;memcpy(bestP,P,sizeof(P));}

        }while(next_permutation(P,P+n));

        for(int i=0;i<n;i++) cout<<letter[bestP[i]]<<" ";

        cout<<"-> "<<ans<<endl;

    }

    return 0;

}

刘汝佳代码

简单总结就是全排列然后计算当前最小带宽

©著作权归作者所有:来自51CTO博客作者Rign的原创作品,如需转载,请注明出处,否则将追究法律责任


点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消