QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#129616 | #5033. Y 君的序列 | pandapythoner# | Compile Error | / | / | C++20 | 3.1kb | 2023-07-22 21:22:14 | 2024-07-04 00:53:23 |
Judging History
你现在查看的是最新测评结果
- [2024-07-04 00:53:23]
- 评测
- 测评结果:Compile Error
- 用时:0ms
- 内存:0kb
- [2023-08-10 23:21:45]
- System Update: QOJ starts to keep a history of the judgings of all the submissions.
- [2023-07-22 21:22:14]
- 提交
answer
#pragma GCC optimize("Ofast,unroll-loops")
#pragma GCC target("avx,avx2,fma")
#include <bits/stdc++.h>
using namespace std;
#define ll long long
#define flt double
#define all(a) a.begin(), a.end()
#define rall(a) a.rbegin(), a.rend()
mt19937 rnd(234);
const ll inf = 1e18;
#include "seq.h"
const int mx_ln = 200;
vector<int> swp(int a, int b) {
if (a % 2 == 1 && b % 2 == 1) {
return {};
}
if ((a + b) % 2 != 1) {
return {};
}
vector<int> rs;
rs.reserve(mx_ln / 2);
int x = a;
int y = b;
while (x != b) {
if (x % 2 == 0) {
x /= 2;
y += x;
rs.push_back(0);
} else {
y /= 2;
x += y;
rs.push_back(1);
}
if (rs.size() > mx_ln || x == a) {
return {};
}
}
return rs;
}
void solve_fuck(vector<int> b, vector<pair<int, int>> &rs) {
int n = b.size();
if (n == 1) {
return;
}
}
vector<pair<int, int>> solve_fuck(int n, int M) {
vector<pair<int, int>> rs;
vector<int> p(n + 1, -1);
vector<vector<int>> t(n + 1, vector<int>());
p[2] = 1;
t[2] = {0};
for (int i = 3; i <= n; i += 1) {
for (int x = 2; x < i && x * x <= i; x += 1) {
if (i % x == 0) {
p[i] = p[i / x] * x;
t[i] = t[i / x];
break;
}
}
for (int j = 1; p[i] == -1 && j < i; j += 1) {
auto f = swp(i, j);
if (!f.empty() && (int)f.size() <= mx_ln) {
p[i] = j;
t[i] = f;
break;
}
}
if (p[i] == -1) {
assert(0);
}
}
vector<int> ra(n + 1), rb(n + 1);
vector<int> a(n + 1);
for (int i = 1; i <= n; i += 1) {
ra[i] = i;
a[i] = i;
rb[Get(i)] = i;
}
for (int k = n; k >= 2; k -= 1) {
int psa = ra[k];
int psb = rb[k];
if (psa != psb) {
int bbr = a[psb];
vector<int> wx, wy;
while (bbr != 1) {
wx.push_back(bbr);
bbr = p[bbr];
}
bbr = k;
while (bbr != 1) {
wy.push_back(bbr);
bbr = p[bbr];
}
reverse(all(wy));
auto w = wx;
for (auto x : wy) {
w.push_back(x);
}
for (auto x : w) {
for (auto s : t[x]) {
if (s == 0) {
rs.emplace_back(ra[x], ra[p[x]]);
} else {
rs.emplace_back(ra[p[x]], ra[x]);
}
}
swap(a[ra[x]], a[ra[p[x]]]);
swap(ra[x], ra[p[x]]);
}
}
}
return rs;
}
void SEQ(int n, int M) {
vector<pair<int, int>> rs = solve_fuck(n, M);
answer(1);
for (auto [i, j] : rs) {
add(i, j);
}
}
/*
10 10000000 1
1 2 3 4 5 6 7 8 9 10
*/
詳細信息
implementer.cpp: In function ‘void {anonymous}::StAr_WaRs::main()’: implementer.cpp:46:22: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 46 | scanf("%d %d",&n,&M); | ~~~~~^~~~~~~~~~~~~~~ implementer.cpp:47:45: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result] 47 | for (int i=1;i<=n;i++) scanf("%d",&b[i]),a[i]=i; | ~~~~~^~~~~~~~~~~~ In file included from /usr/include/c++/13/string:43, from /usr/include/c++/13/bitset:52, from /usr/include/x86_64-linux-gnu/c++/13/bits/stdc++.h:52, from answer.code:4: /usr/include/c++/13/bits/allocator.h: In destructor ‘constexpr std::_Vector_base<int, std::allocator<int> >::_Vector_impl::~_Vector_impl()’: /usr/include/c++/13/bits/allocator.h:184:7: error: inlining failed in call to ‘always_inline’ ‘constexpr std::allocator< <template-parameter-1-1> >::~allocator() noexcept [with _Tp = int]’: target specific option mismatch 184 | ~allocator() _GLIBCXX_NOTHROW { } | ^ In file included from /usr/include/c++/13/vector:66, from /usr/include/c++/13/functional:64, from /usr/include/x86_64-linux-gnu/c++/13/bits/stdc++.h:53: /usr/include/c++/13/bits/stl_vector.h:133:14: note: called from here 133 | struct _Vector_impl | ^~~~~~~~~~~~