解析:
这道题的突破口就是**最多只有十张纸片,**所以我们可以枚举所有收集的顺序,
全排列可以用这个函数: next_permutation(d+1, d + k+1)
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
struct node
{
int x,y;
}a[10005];
int d[1005];
int t,k;
int n,m;
int main()
{
cin>>t;
while(t--)
{
scanf("%d %d",&n,&m);
scanf("%d %d",&a[0].x,&a[0].y);
scanf("%d",&k);
d[0]=0;
for(int i=1;i<=k;i++)
{
scanf("%d %d",&a[i].x,&a[i].y);
d[i]=i;
}
ll ans=0;
ll minn=0x3f3f3f3f;
do
{
ans=0;
for(int i=1;i<=k;i++)
{
ans=ans+abs(a[d[i]].x-a[d[i-1]].x)+abs(a[d[i]].y-a[d[i-1]].y);
}
ans=ans+abs(a[d[k]].x-a[0].x)+abs(a[d[k]].y-a[0].y);
minn=min(minn,ans);
}while(next_permutation(d+1, d + k+1));
printf("The shortest path has length %lld\n",minn);
}
}