QOJ.ac

QOJ

ID题目提交者结果用时内存语言文件大小提交时间测评时间
#605353#9428. Be Positivehuangzihao123WA 29ms7780kbC++201.3kb2024-10-02 16:47:392024-10-02 16:47:39

Judging History

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

  • [2024-10-02 16:47:39]
  • 评测
  • 测评结果:WA
  • 用时:29ms
  • 内存:7780kb
  • [2024-10-02 16:47:39]
  • 提交

answer

#include<bits/stdc++.h>
using namespace std;
#define int long long
#define endl '\n'
#define io ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)
#define all(a) a.begin(),a.end()
typedef pair<int,int> PII;
typedef long long LL;
const int N = 1e6;
const int mod = 998244353;
inline int ls(int x) { return x << 1; }
inline int rs(int x) { return x << 1 | 1; }
int dx[8] = { 1,0,0,-1,-1,-1,1,1 };
int dy[8] = { 0,-1,1,0,-1,1,-1,1};
inline int gcd(int a, int b)
{
   if (b) while ((a %= b) && (b %= a));
   return a + b;
}
int vis[N + 5];
void solve()
{
    int n;
    cin >> n;
    if(n == 2){
        cout << "1 0" << endl;
        return;
    }
    if(n == 3){
        cout << "1 0 2" << endl;
        return;
    }
    if(vis[n]){
        cout << "impossible" << endl;
        return;
    }
    cout << "1 0 2 4 3 ";
    int now = 5;
    while(now < n){
        if(vis[now + 1]){
            cout << now + 1 << ' ' << now << ' ';
            now += 2;
        }
        else {
            cout << now << ' ';
            now++;
        } 
    }
    cout << endl;
    
}
signed main()
{
    io;
    int tt = 1;
    int now = 1;
    while(now <= N){
        vis[now] = 1;
        now *= 2;
    }
    cin >> tt;
    while(tt--)
    {
        solve();
    }
	return 0;
}

詳細信息

Test #1:

score: 100
Accepted
time: 1ms
memory: 7740kb

input:

4
1
2
3
4

output:

impossible
1 0
1 0 2
impossible

result:

ok 4 test cases (4 test cases)

Test #2:

score: 0
Accepted
time: 1ms
memory: 7776kb

input:

10
1
2
3
4
5
6
7
8
9
10

output:

impossible
1 0
1 0 2
impossible
1 0 2 4 3 
1 0 2 4 3 5 
1 0 2 4 3 5 6 
impossible
1 0 2 4 3 5 6 8 7 
1 0 2 4 3 5 6 8 7 9 

result:

ok 10 test cases (10 test cases)

Test #3:

score: -100
Wrong Answer
time: 29ms
memory: 7780kb

input:

1413
1392
1306
297
726
1353
1059
111
758
1409
843
1013
940
1186
788
60
230
1249
209
776
966
178
25
168
494
70
867
601
195
718
497
1161
323
1054
265
148
388
186
539
760
1184
1230
829
400
460
1253
922
903
42
1347
1368
404
512
1170
378
136
560
1078
612
1201
30
717
934
572
975
255
1131
319
629
264
1240
...

output:

1 0 2 4 3 5 6 8 7 9 10 11 12 13 14 16 15 17 18 19 20 21 22 23 24 25 26 27 28 29 30 32 31 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 64 63 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 10...

result:

wrong answer xor equals zero (test case 1)