제출 #228317

#제출 시각아이디문제언어결과실행 시간메모리
228317chctxdy68Arranging Shoes (IOI19_shoes)C++14
컴파일 에러
0 ms0 KiB
#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
#define fastio ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0)
#define ll long long
#define ull unsigned long long
#define ld long double
#define pii pair <int, int>
#define pll pair <ll, ll>
#define pci pair <char, int>
#define pld pair <ld, ld>
#define ppld pair <pld, pld>
#define ppll pair <pll, pll>
#define pldl pair <ld, ll>
#define vll vector <ll>
#define vvll vector <vll>
#define vpll vector <pll>
#define pb push_back
#define eb emplace_back
#define mp make_pair
#define fi first
#define se second
#define mll map <ll, ll>
#define fastmap gp_hash_table
#define cd complex <double>
#define vcd vector <cd>
#define PI 3.14159265358979
#define ordered_set tree <ll, null_type, less <ll>, rb_tree_tag, tree_order_statistics_node_update>
#pragma 03
#include "shoes.h"
using namespace std;
using namespace __gnu_pbds;
queue <ll> rs[100005], ls[100005];
ll st[800005];
bool marked[200005];
void update(ll root, ll l, ll r, ll i, ll val){
	if (i < l || i > r) return;
	if (l == r){
		st[root] = val; return;
	} 
	ll mid = (l + r) / 2;
	update(root * 2 + 1, l, mid, i, val);
	update(root * 2 + 2, mid + 1, r, i, val);
	st[root] = st[root * 2 + 1] + st[root * 2 + 2];
}
ll query(ll root, ll l, ll r, ll x, ll y){
	if (y < l || x > r) return 0;
	if (x <= l && y >= r) return st[root];
	ll mid = (l + r) / 2;
	return query(root * 2 + 1, l, mid, x, y) + query(root * 2 + 2, mid + 1, r, x, y);
}
ll count_swaps(vll a){
	for (ll i = 0; i < a.size(); i++){
		if (a[i] < 0) ls[-a[i]].push(i);
		else rs[a[i]].push(a[i]);
	}
	ll ans = 0;
	ll n = a.size();
	for (ll i = 0; i < a.size(); i++) update(0, 0, n - 1, i, 1);
	for (ll i = 0; i < a.size(); i++){
		if (marked[i]) continue;
		marked[i] = 1;
		if (a[i] < 0){
			ll p = rs[-a[i]].front(); rs[-a[i]].pop();
			if (i + 1 <= p - 1) ans += query(0, 0, n - 1, i + 1, p - 1);
			update(0, 0, n - 1, i, 0); update(0, 0, n - 1, p, 0);
			marked[p] = 1;
		}
		else{
			ll p = ls[a[i]].front(); ls[a[i]].pop();
			if (i + 1 <= p - 1) ans += (query(0, 0, n - 1, i + 1, p - 1));
			ans++;
			update(0, 0, n - 1, i, 0); update(0, 0, n - 1, p, 0);
			marked[p] = 1;
		}
	}
	return ans;
}

컴파일 시 표준 에러 (stderr) 메시지

shoes.cpp:29:0: warning: ignoring #pragma 03  [-Wunknown-pragmas]
 #pragma 03
 
shoes.cpp: In function 'long long int count_swaps(std::vector<long long int>)':
shoes.cpp:53:19: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for (ll i = 0; i < a.size(); i++){
                 ~~^~~~~~~~~~
shoes.cpp:59:19: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for (ll i = 0; i < a.size(); i++) update(0, 0, n - 1, i, 1);
                 ~~^~~~~~~~~~
shoes.cpp:60:19: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
  for (ll i = 0; i < a.size(); i++){
                 ~~^~~~~~~~~~
/tmp/ccfeoPer.o: In function `main':
grader.cpp:(.text.startup+0x272): undefined reference to `count_swaps(std::vector<int, std::allocator<int> >)'
collect2: error: ld returned 1 exit status