CF1204C-Anna, Святослава и Карты
Значение вопросов:
Тема Портал
не хочу сказать, прочитал название.
Решение:
Флойд провел первый с кратчайшим путем между вершинами. Р (. 1) добавляет к ответу, а затем по пути к предмету последовательности обходу, если ответ на последнюю вершину кратчайшего расстояния от вершины до текущей итерации, меньше, чем расстояние между двумя точками в исходной последовательности, и, вместе с ответом р (I-1), и продолжает проходить путь, пройденный после последнего добавления р (м)
КОД:
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int INF = 0x3f3f3f3f;
#define LL long long
#define N 110
int e[N][N],ans[N*N*N];
int p[N*N*N],n,m,cnt;
void floyd() {
for(int k = 1 ; k <= n ; k++) {
for(int i = 1 ; i <= n ; i++) {
for(int j = 1 ; j <= n ; j++) {
e[i][j] = min(e[i][j],e[i][k] + e[k][j]);
}
}
}
}
int main(){
scanf("%d",&n);
getchar();
for(int i = 1 ; i <= n ; i++) {
for(int j = 1 ; j <= n ; j++) {
char t = getchar();
e[i][j] = (t == '1') ? 1 : INF;
if(i == j) e[i][j] = 0;
}
getchar();
}
scanf("%d",&m);
for(int i = 1 ; i <= m ; i++)
scanf("%d",&p[i]);
floyd();
ans[++cnt] = p[1];
int dis = 0;
for(int i = 2 ; i <= m ; i++) {
dis += e[p[i - 1]][p[i]];
if(dis > e[ans[cnt]][p[i]]){
ans[++cnt] = p[i - 1];
dis = e[ans[cnt]][p[i]];
}
}
ans[++cnt] = p[m];
printf("%d \n",cnt);
for(int i = 1 ; i <= cnt ; i++)
printf("%d ",ans[i]);
//system("pause");
return 0;
}