QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#666865 | #7757. Palm Island | miku | WA | 1ms | 5528kb | C++20 | 1.3kb | 2024-10-22 20:14:50 | 2024-10-22 20:14:58 |
Judging History
answer
#include<bits/stdc++.h>
#define pb push_back
#define x first
#define y second
#define endl '\n'
using namespace std;
using ll =long long ;
using pii =pair<int,int>;
using pll=pair<ll,ll>;
bool cmp(pll a,pll b){
return a.y<b.y;
}
struct cmp1{
bool operator()(pair<ll,ll>a,pair<ll,ll>b){
if(a.x==b.x)return a.y>b.y;
return a.x>b.x;
}
};
const int mod=998244353;
ll ksm(ll a,ll b){ll ans=1;while(b){if(b&1){ans*=a;ans=ans%mod;}a=a*a;a%=mod;b>>=1;}return ans;}
ll gcd(ll a,ll b){ll t=a%b;while(t){a=b;b=t;t=a%b;}return b;}
ll lcm(ll a,ll b){return a/gcd(a,b)*b;}
ll get_inv(ll x){return ksm(x,mod-2);}
const int N=5e5+10;
ll a[N];
ll b[N];
void solve(){
int n;
cin>>n;
map<int,int>mp;
for(int i=1;i<=n;i++){
cin>>a[i];
}
int idx=0;
for(int i=1;i<=n;i++){
cin>>b[i];
mp[b[i]]=++idx;
}deque<ll>dq;
for(int i=1;i<=n;i++){
a[i]=mp[a[i]];
dq.pb(a[i]);
}
vector<int>v;
for(int i=1;i<=n*(n-1)/2;i++){
if(dq[0]<dq[1]){
v.pb(1);v.pb(2);dq.pb(dq[0]);dq.pb(dq[1]);
}
else{
v.pb(2);v.pb(1);dq.pb(dq[1]);dq.pb(dq[0]);
}
dq.pop_front();dq.pop_front();
}
if(dq[0]!=1){
int w=n-dq[0]+1;
while(w--)v.pb(1);
}
for(auto c:v)cout<<c;cout<<endl;
}
int main(){
ios::sync_with_stdio(false);cin.tie(0);
int _=1;
cin>>_;
while(_--)solve();
return 0;
}
详细
Test #1:
score: 0
Wrong Answer
time: 1ms
memory: 5528kb
input:
2 3 1 2 3 2 3 1 4 1 2 3 4 2 1 3 4
output:
21212111 211212121212
result:
wrong answer On Case#1: After your operations, a[1] = 1 but a[1] = 2. (test case 1)