cogs5. P服务点设置

★★   输入文件:djsc.in   输出文件:djsc.out   简单对比

时间限制:2 s  
内存限制:128 MB

问题描述

为了进一步普及九年义务教育,政府要在某乡镇建立P所希望小学,该乡镇共有n个村庄,村庄间的距离已知,请问学校建在哪P个村庄最好?(好坏的标准是学生就近入学,即在来上学的学生中,以最远的学生走的路程为标准。或者说最远的学生与学校的距离尽可能的小。)

【输入格式】

输入由若干行组成,第一行有3个整数,n(1≤n≤100)、m(1≤m≤n2),p;n表示村庄数,m表示村庄间道路数。第2至m+1行是每条路的信息,每行三个整数,为道路的起点、终点和两村庄间距离。(村庄从0开始编号)

【输出格式】

P个整数,学校所在村庄编号(如果P个以上村庄都适合建立学校,选择编号小的P个村庄建学校,输出时按编号从小到大输出)。

【输入样例】

输入文件名:djsc.in

6 8 2

0 2 10

0 4 30

0 5 100

1 2 5

2 3 50

3 5 10

4 3 20

4 5 60

【输出样例】

输出文件名:djsc.out

0 3

floyd+dfs:

    #include<cstdio>
    #include<cstring>
    #include<climits>
    #include<algorithm>
    #include<iostream>
    #define min(a,b) ((a)<(b)?(a):(b))
     using namespace std;
    int n,m,p;
    int a[101][101];
    int rec[101],ans[101];
    bool b[101]={0};
    int maxn=INT_MIN,minn=INT_MAX,mnn=INT_MAX;

    void init();
    void work();
    void outit();
    void dfs(int );

    int main()
    {
        freopen("djsc.in","r",stdin);
           freopen("djsc.out","w",stdout);
         init();
        work();
        outit();
        return 0;
    }
    void init()
    {
        scanf("%d%d%d",&n,&m,&p);
        memset(a,0x3f,sizeof(a));
        for(int i=0;i<m;i++)
        {
            int x,y,z;
            scanf("%d%d%d",&x,&y,&z);
            a[x][y]=z;
            a[y][x]=z;
        }
        for(int i=0;i<n;i++)a[i][i]=0;
    }
    void work()
    {
        for(int k=0;k<n;k++)
        for(int i=0;i<n;i++)
        for(int j=0;j<n;j++)
        a[i][j]=min(a[i][j],a[i][k]+a[k][j]);
        dfs(1);
    }
    void outit()
    {
        std::sort(ans+1,ans+p+1);
        for(int i=1;i<=p;i++)
            printf("%d ",ans[i]);
    }
    void dfs(int x)//x当前点、num已选点数
    {
        if(x==p+1)//说明上一个num为p
        {
            maxn=INT_MIN;
            for(int i=0;i<n;i++)//找题意中p个点到其他所有点的最远距离
            {
                bool flag=false;
                minn=INT_MAX;
                for(int j=1;j<=p;j++)//该方案中每个点到i的距离,找最短的
                {
                    if(!a[i][rec[j]])//也就是rec[j]=i,直接跳过
                    {flag=1;break;}
                    if(a[i][rec[j]]<minn)
                    minn=a[i][rec[j]];
                }
                if(!flag&&minn>maxn)maxn=minn;//最短中的最长的
            }
            if(maxn<mnn)//比上一个方案更优,更新
            {
                mnn=maxn;
                for(int j=1;j<=p;j++)
                ans[j]=rec[j];
            }
            return ;
        }
        for(int i=0;i<n;i++)
        {
            if(!b[i])
            {
                b[i]=1;
                rec[x]=i;
                dfs(x+1);
                b[i]=0;

            }
        }
    }
时间: 2024-12-15 01:54:26

cogs5. P服务点设置的相关文章

cogs 双服务点设置

4. 双服务点设置 ☆   输入文件:djsb.in   输出文件:djsb.out   简单对比时间限制:1 s   内存限制:128 MB 问题描述为了进一步普及九年义务教育,政府要在某乡镇建立两所希望小学,该乡镇共有n个村庄,村庄间的距离已知,请问学校建在哪两个村庄最好?(好坏的标准是学生就近入学,即在来上学的学生中,以最远的学生走的路程为标准.或者说最远的学生与学校的距离尽可能的小.) [输入格式] 输入由若干行组成,第一行有两个整数,n(1≤n≤50).m(1≤m≤n∗n):n表示村庄

cogs服务点设置(不凶,超乖) x

cogs3. 服务点设置 ★   输入文件:djsa.in   输出文件:djsa.out   简单对比时间限制:1 s   内存限制:128 MB 问题描述为了进一步普及九年义务教育,政府要在某乡镇建立一所希望小学,该乡镇共有n个村庄,村庄间的距离已知,请问学校建在哪个村庄最好?(好坏的标准是学生就近入学,即在来上学的学生中,以最远的学生走的路程为标准.或者说最远的学生与学校的距离尽可能的小.) [输入格式] 输入由若干行组成,第一行有两个整数,n(1≤n≤100).m(1≤m≤n*n):n表

COGS 双 服务点设置

☆   输入文件:djsb.in   输出文件:djsb.out   简单对比 时间限制:1 s   内存限制:128 MB 问题描述 为了进一步普及九年义务教育,政府要在某乡镇建立两所希望小学,该乡镇共有n个村庄,村庄间的距离已知,请问学校建在哪两个村庄最好?(好坏的标准是学生就近入学,即在来上学的学生中,以最远的学生走的路程为标准.或者说最远的学生与学校的距离尽可能的小.) [输入格式] 输入由若干行组成,第一行有两个整数,n(1≤n≤50).m(1≤m≤n?n):n表示村庄数,m表示村庄间

央行发文深入推进农村支付服务环境建设并答记者问

昨日,央行发布<全面推进深化农村支付服务环境建设的指导意见>,主要从深化助农取款服务,优化农民工银行卡特色服务,推广非现金支付等方面,对下一步深化农村支付环境建设工作提出要求. 一是将深化助农取款服务作为核心内容.允许在银行卡助农取款服务点新增开办现金汇款.转账汇款.代理缴费三种业务,丰富服务功能. 二是明确服务点业务收费要兼顾可持续发展和适度优惠农民的指导原则.特别是对于农村老人在服务点支取养老金等政府涉农补贴资金,要求每卡每月首笔取款业务免费. 三是鼓励支持农村支付服务主体多元化发展,推动

企业做网络推广关键词设置的几点个人看法

如何挑选正确的关键词 如何挑选关键词是网络推广中最重要的步骤之一,同时也是大多数企业在做网络推广时候容易忽视的问题.都认为找出几个行业内的热门关键词,将关键词推广到到搜索引擎前几页,就能得到好的推广效果.殊不知此举通常是延误网络推广最佳时机,更不会在推广期间为你带来理想的效果的,因为你的词中可能包含一些极热门的单词,比如"婚纱摄影"."手机"或"服装批发"--等等.它们实在太热门了,绝大部分网站都用了几年的时间以它们作为目标关键词参与竞争,即营销

linux下Nginx配置文件(nginx.conf)配置设置详解(windows用phpstudy集成)

linux备份nginx.conf文件举例: cp /usr/local/nginx/nginx.conf /usr/local/nginx/nginx.conf-20171111(日期) 在进程列表里 面找master进程,它的编号就是主进程号. ps -ef | grep nginx 查看进程 cat /usr/local/nginx/nginx.pid 每次修改完nginx文件都要重新加载配置文件linux命令: /usr/local/nginx -t //验证配置文件是否合法 若ngin

win7设置固定IP重启后无法上网,ipconfig显示为自动配置IPV4 169.254的地址

近日安装原版Win7系统打完网卡驱动补丁后,给电脑设置了固定的IP地址后一切正常,但是电脑重启后发现上不了网了,右下角网络图标有个感叹号,打开网络和共享中心-->本地连接-->详细信息-->发现IPv4的地址与ipconfig /all得到的IP地址一致,均显示为:自动配置IPv4地址:169.254.123.188(首选) 但是查看本地连接-->属性里看到之前设置的固定IP地址是没有问题的, 所以想到了应该是电脑启用了自动配置IPv4功能,导致了固定IP无法分配给电脑, 尝试用命

【Windows10&nbsp;IoT开发系列】开发人员模式设置

原文:[Windows10 IoT开发系列]开发人员模式设置  声明:本文转自微软Windows 开发人员中心(https://msdn.microsoft.com/library/windows/apps/xaml/dn706236.aspx),在此基础上进行删减和修改. ​对于要用于开发.安装或测试应用的设备,不再需要开发人员许可证.你只需从设备的设置中为这些任务启用设备一次.(仅限于运行Windows 10系统的设备) 使用开发人员功能 ​使用 Microsoft Visual Stud

easyui-textbox 和 easyui-validatebox 设置值和获取值

表单作如下定义:该input使用easyui的"easyui-textbox" 1 <input id="addSnumber" style="width: 200px; height: 30px;" class="easyui-textbox" type="text" name="snumber" data-options="required:true, missing