这道题不难,但是map里的一个操作也卡了我MLE
我之前用map去查询的时候这么写t1=mp[tem];这样不好的是如果tem不存在,会自动插入map一组值,导致内存消耗巨大。。。。改成传统查询方法就可以了。
言归正传,说说这道题,首先n^2的建图是必然T的,然后就不会了,后来队友提醒,连边的条件 的很强,只能有一个位置不同或者有两个位置不同但交换后便相同,这样一个点的可能连边数是10*9+10*9/2=135,复杂度马上就下来了,诶,自己以后做题还是要多想想,善于挖掘条件!
[cpp]
#include
#include
#include
#include
int val[20],n;
ll s[50010],tem,t1,t2;
ll p[20];
bool vis[50010];
int pre[50010],dp[50010];
vector v;
void init(){
memset(head,-1,sizeof(head));
cnt=0;
}
void addedge(int u,int v,int w){
int i;
edge[cnt].v=v;
edge[cnt].w=w;
edge[cnt].next=head[u];
head[u]=cnt++;
}
bool spfa(){
int i,u,v;
memset(vis,0,sizeof(vis));
queueq;
q.push(0);