Princess CJB has lived almost her entire life in the isolated town of Ertona, where CJB uses her unique ability to recognize where crystals of materials are buried. By way of a fateful encounter, CJB learns of the Alchemy Exam and decides to take her first step into the outside world, setting off on a grand journey to become a certified alchemist and discover the mysteries that life has to offer!
In order to take part in the Alchemy Exam, CJB goes to the Reisenberg town without any partners. But the kingdom Adalet is unbelievably enormous so that there are many hidden risks. Claris, a powerful evil magician, wants to monopolize CJB for the extraordinary beauty of her. Due to the power limitation of CJB, she can’t escape from Claris without any assistance. The alchemist Tokitsukaze has heard this savage act and wants to rescue the princess CJB.
There are n cities numbered from 1 to n in the kingdom Adalet. Because of the excellent transportation, there is exactly a two-way road between any two cites. Tokitsukaze lives in city 1. The Magician Claris lives in city n. Since the exam will be held soon, Tokitsukaze wants to rescue CJB as fast as possible, so she will choose the shortest path to reach city n.
Claris has also heard this news and is afraid of being punished, so he decides to slow Tokitsukaze down by making an explosion on k roads he chose and causing these roads to lose their capability of two-way transportation, since it can pave the way for having enough time to prepare his powerful magic against Tokitsukaze.
Tokitsukaze knows some roads will be destroyed and can immediately recognize where they are, but she has no approach to prevent this explosion, so she chooses just to move along the shortest path after Claris completes his explosion.
Now Claris wants to know, after finishing his explosion, what the longest possible length is of the shortest path from city 1 to city n.
我们先跑一遍最短路,然后删的边一定是这条最短路的某条边,然后dfs枚举每种情况。 虽然刚开始我觉得会t,但是有位大佬计算了一下期望,因为边的权值是随机的嘛,所以他算出最短路的路径长度的期望为3.5左右。%%%
大佬的博客
#include
using namespace std;
typedef long long ll;
typedef pair<int,int> pii;
typedef unsigned long long ull;
const int N=52;
const int inf=0x3f3f3f3f;
int n,m,k;
int d[N];
int w[N][N],pre[N],vis[N];
int res;
void dij(int pre[])
{
memset(vis,0,sizeof vis);
memset(d,0x3f,sizeof d);
d[1]=0;
for(int k=1;k<=n-1;k++)
{
int t=inf,flag=0;
for(int i=1;i<=n;i++)
{
if(!vis[i]&&d[i]<t) t=d[i],flag=i;
}
vis[flag]=1;
for(int i=1;i<=n;i++)
{
if(w[flag][i]<inf && !vis[i])
{
if(d[i]>d[flag]+w[flag][i])
d[i]=d[flag]+w[flag][i],pre[i]=flag;
}
}
}
}
void dfs(int x)
{
if(x==k+1)
{
dij(pre);
res=max(res,d[n]);
return ;
}
int pre[N]={0};
dij(pre);
int now=n;
while(pre[now])
{
int t=w[pre[now]][now];
w[pre[now]][now]=w[now][pre[now]]=inf;
dfs(x+1);
w[pre[now]][now]=w[now][pre[now]]=t;
now=pre[now];
}
}
int main()
{
//freopen("test.in","r",stdin);//设置 cin scanf 这些输入流都从 test.in中读取
//freopen("test.out","w",stdout);//设置 cout printf 这些输出流都输出到 test.out里面去
//ios::sync_with_stdio(false);
//cin.tie(0),cout.tie(0);
int T;
cin>>T;
while(T--)
{
cin>>n>>k;
m=n*(n-1)/2;
res=0;
for(int i=0;i<m;i++)
{
int a,b,c;
scanf("%d%d%d",&a,&b,&c);
w[a][b]=w[b][a]=c;
}
dfs(1);
cout<<res<<endl;
}
return 0;
}