QOJ.ac

QOJ

IDProblemSubmitterResultTimeMemoryLanguageFile sizeSubmit timeJudge time
#198057#3858. Systematic salesmanForever_YoungCompile Error//C++143.6kb2023-10-03 00:32:482023-10-03 00:32:49

Judging History

你现在查看的是最新测评结果

  • [2023-10-03 00:32:49]
  • 评测
  • [2023-10-03 00:32:48]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
#define fi first
#define se second
#define pb push_back
typedef double D;
typedef pair<int, int> pii;
int nc = 0;
const int N = 1011;
const int LOG = 11;
D mp[LOG][N][N];
pii u[LOG][N][N];
struct H {
    size_t operator()(const pii & k) const {
        return hash<int>()(k.fi * N + k.se);
    }
};
int x[N][2], o[N], ls[N], rs[N];
D dis[N][N];
vector<int> vec;
void print(pii p, int dep) {
	 if(p.fi == p.se) {
		vec.pb(p.fi);
		return;
	 }
	 
	 pii u = ::u[dep][p.fi][p.se];
	 pii q{p.fi, u.fi}, r{u.se, p.se};
	 print(q, dep + 1);
	 print(r, dep + 1);
}
D tmp[N][N];
int tmpu[N][N];
void solve(int le, int ri, int d, int dep) {
	//printf("%d %d %d %d\n", le, ri, d, dep);
	if(le == ri - 1) {
		mp[dep][o[le]][o[le]] = 0;
		//printf("!%d\n", o[le]);
		return;
	}
	sort(o + le, o + ri, [&](int a, int b) { return x[a][d] < x[b][d]; });
	int mid = (ri + le) / 2;
	solve(le, mid, d ^ 1, dep + 1);
	solve(mid, ri, d ^ 1, dep + 1);
	if(dep == 0) {
		static D mn[N];
		static int mnp[N];
		for(int i = le; i < ri; i++) {
			int x = o[i];
			mn[x] = 1e50;
			mnp[x] = -1;
			for(int j = le; j < ri; j++) {
				int y = o[j];
				if(mp[1][x][y] < mn[x]) {
					mn[x] = mp[1][x][y];
					mnp[x] = y;
				}
			}
		}
		D ans = 1e50;
		pii px, py;
		for(int i = le; i < mid; i++) {
			for(int j = mid; j < ri; j++) {
				int x = o[i];
				int y = o[j];
				if(mn[x] + mn[y] + dis[x][y] < ans) {
					ans = mn[x] + mn[y] + dis[x][y];
					px = pii{mnp[x], x};
					py = pii{y, mnp[y]};
				}
			}
		}
		printf("%.12f\n", (double)ans);
		print(px, 1);
		print(py, 1);
		return;
	}
	//if(dep >= 9) printf("!!!!!!!!%d %d %d %d %d\n", le, mid, ri, o[le], o[mid]);

	for(int i = le; i < mid; i++) {
		int x = o[i];
		for(int j = le; j < mid; j++) {
			int y = o[j];
			for(int k = mid; k < ri; k++) {
				int z = o[k];
				D d = mp[dep + 1][x][y] + dis[y][z];
				if(d < tmp[x][z]) {
					tmp[x][z] = d;
					tmpu[x][z] = y;
				}
			}
		}
	}

	for(int i = le; i < mid; i++) {
		int x = o[i];
		for(int k = mid; k < ri; k++) {
			int z = o[k];
			for(int l = mid; l < ri; l++) {
				int w = o[l];
				D d = tmp[x][z] + mp[dep + 1][z][w];
				//if(dep >= 9) printf("%d %d %d %d %lf %lf\n", x, y, z, w, (double)d, (double)mp[dep][x][w]);
				//printf("%lf %lf %lf %lf %lf\n",  (double)mp[dep][x][w],  (double)mp[dep + 1][x][y],   (double)mp[dep + 1][z][w],   (double)dis[y][z],  (double)d);
				if(d < mp[dep][x][w]) {
					//if(dep >= 9) printf("%d %d->%d = %lf\n", dep, x, w, (double)d);
					mp[dep][x][w] = d;
					u[dep][x][w] = pii{tmpu[x][z], z};
					mp[dep][w][x] = d;
					u[dep][w][x] = pii{z, tmpu[x][z]};
				}
			}
		}
	}
	for(int i = le; i < mid; i++) {
		int x = o[i];
		for(int k = mid; k < ri; k++) {
			int z = o[k];
			tmp[x][z] = 1e50;
		}
	}

}
int main() {
	int n;
	scanf("%d", &n);
	//n = 1000;
	for(int i = 0; i < LOG; i++) {
		for(int j = 0; j < n; j++) {
			for(int k = 0; k < n; k++) {
		
				mp[i][j][k] = 1e50;
				tmp[j][k] = 1e50;
			}
		}
	}
	if(n == 1) { printf("0\n1\n"); exit(0); }
	for(int i = 0; i < n; i++) {
		scanf("%d%d", &x[i][0], &x[i][1]);
		//x[i][0] = i;
		//x[i][1] = i;
		o[i] = i;
	}
	for(int i = 0; i < n; i++) {
		for(int j = 0; j < n; j++) {
			dis[i][j] = (LL)(x[i][0] - x[j][0]) * (x[i][0] - x[j][0]) + (LL)(x[i][1] - x[j][1]) * (x[i][1] - x[j][1]);
			dis[i][j] = sqrt(dis[i][j]);
		}
	}
	solve(0, n, 0, 0);

	for(int i = 0; i < n; i++) {
		printf("%d%c", vec[i] + 1, i == n - 1 ? '\n' : ' ');
	}
	//cout << clock() << endl;
}

Details

answer.code: In function ‘int main()’:
answer.code:145:38: error: ‘LL’ was not declared in this scope
  145 |                         dis[i][j] = (LL)(x[i][0] - x[j][0]) * (x[i][0] - x[j][0]) + (LL)(x[i][1] - x[j][1]) * (x[i][1] - x[j][1]);
      |                                      ^~
answer.code:125:14: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
  125 |         scanf("%d", &n);
      |         ~~~~~^~~~~~~~~~
answer.code:138:22: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
  138 |                 scanf("%d%d", &x[i][0], &x[i][1]);
      |                 ~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~