結果
| 問題 |
No.1006 Share an Integer
|
| コンテスト | |
| ユーザー |
lyulu
|
| 提出日時 | 2020-03-06 21:53:16 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 1,483 bytes |
| コンパイル時間 | 1,707 ms |
| コンパイル使用メモリ | 180,300 KB |
| 実行使用メモリ | 10,496 KB |
| 最終ジャッジ日時 | 2024-10-14 06:35:39 |
| 合計ジャッジ時間 | 5,322 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | WA * 3 |
| other | AC * 1 WA * 7 TLE * 1 -- * 10 |
ソースコード
#include <bits/stdc++.h>
#define rep(i, n) for(int i = 0; i < n; ++i)
#define rrep(i, n) for(int i = n-1; i >= 0; --i)
#define fi first
#define se second
using namespace std;
using lint = long long;
using uint = unsigned int;
using ulint = unsigned long long;
using ldouble = long double;
using pii = pair<int, int>;
using pli = pair<lint, lint>;
using pdd = pair<double, double>;
using pld = pair<ldouble, ldouble>;
using v1i = vector<int>;
using v1li = vector<lint>;
using v2i = vector<vector<int>>;
using v2li = vector<vector<lint>>;
using v3i = vector<vector<vector<int>>>;
using v3li = vector<vector<vector<lint>>>;
using v1b = vector<bool>;
using v2b = vector<vector<bool>>;
using v3b = vector<vector<vector<bool>>>;
using v1c = vector<char>;
using v2c = vector<vector<char>>;
using v3c = vector<vector<vector<char>>>;
constexpr lint mod1 = 1e9+7;
int f(int n){
map<int, int> m;
int a = n, s = 1;
for(int j = 2; j <= pow(n, 0.5); ++j){
int b = 0;
while(a % j == 0){
a /= j;
++b;
}
if(b != 0) m[j] = b;
if(a == 1) break;
}
if(a != 1 && !m.count(a)) m[a] = 1;
for(auto c: m){
s *= c.se;
}
return n-s;
}
int main() {
int x, m;
cin >> x;
vector<pii> v;
rep(i, x/2) v.push_back(make_pair(abs(f(i+1) == f(x-i-1)), i+1));
sort(v.begin(), v.end());
m = v[0].fi;
rep(i, x/2) if(v[i].fi == m) cout << v[i].se << " " << x-v[i].se << endl;
return 0;
}
lyulu