ZOJ-2433 修路

2433:一条高速路沿线有很多城市,间距不等,但高速路是单行的。现在要修两条反向的路使车辆可以返回任意村子。求使总路程最小的两条路地起点和终点。同时要求每个城市最多只能有一条路。

----
A B C D E 这种不行,过了D就回不到前面去了。
----

分析后发现,两条路必须有重叠部分,而且第一个城市和最后一个城市必须包括在内。为了总路程最短,重叠部分为两个相邻城市的间隔

-------
A B C D E 总路程为全长加重叠。问题转化为寻找相邻最近的两城市。
-----------



#include<stdio.h>
#include<iostream>
using namespace std;

int main()
{
int N;
int S1;
int E1=1;
int S2;
int E2;
int num; //city number
int prev; //previous city
int curr; //current city
int min; //minimum dis between two city
int tmp;
int total; //dis between first and last

cin>>N;
for(int i=0;i<N;i++)
{
cin>>num;
S2=num;
for(int k=1;k<num;k++)
{
cin>>curr;
if(k==1)
{
prev=curr;
}
else if(k==2)
{
min=curr-prev;
E2=k;
S1=k+1;
prev=curr;
}
else if(k==num-1)
{
total=curr;
}
else
{
tmp=curr-prev;
if(tmp<min)
{
min=tmp;
E2=k;
S1=k+1;
}
prev=curr;
}
}

if(num<4)
{
cout<<0<<endl;
}
else
{
//total length
cout<<total+min<<endl;
cout<<S1<<" "<<E1<<" "<<S2<<" "<<E2<<endl;
}


if(i!=N-1)
cout<<endl;

}


}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值