提出 #73294007
ソースコード 拡げる
#include <bits/stdc++.h>
#include <iostream>
#include <cmath>
#include <algorithm>
#include <vector>
#include <random>
#include <atcoder/dsu>
#include <atcoder/modint>
#include <atcoder/segtree>
#include <atcoder/lazysegtree>
#include <atcoder/fenwicktree>
#include <atcoder/math>
using namespace std;
using namespace atcoder;
#define all(v) v.begin(), v.end()
#define rall(v) v.rbegin(), v.rend()
#define rep(i, n) for (ll i = 0; i < (ll)(n); i++)
#define rrep(i,n) for (ll i = n-1; i >= 0; i--)
#define rep1(i, n) for (ll i = 1; i < (ll)(n+1); i++)
#define rep3(i, s, t) for(ll i = s; i < (ll)(t); i++)
//#define ll int64_t
#define ll long long
#define pb push_back
#define p(s) cout<<(s)<<'\n'
#define p2(s, t) cout << (s) << " " << (t) << '\n'
#define p3(s, t, u) cout << (s) << " " << (t) << " " << (u) << '\n'
#define p4(s, t, u, v) cout << (s) << " " << (t) << " " << (u) << " " << (v) << '\n'
template<class T>
inline int sz(const T& x) { return (int)x.size(); }
#define Sort(A) sort(all(A))
#define RSort(A) sort(rall(A))
#define p_yes() p("Yes")
#define p_no() p("No")
#define pe(s) cout <<(s)<<' ';
#define pval(s) cout << (s).val() << '\n'
using inverse_priority_queue = priority_queue<ll, vector<ll>, greater<ll>>;//小さい順のpriority_queue
const ll Inf = 2147483647;
const ll Inf9 = 1000000000;
const ll inf = 9223372036854775807;
const ll inf18 = 1000000000000000000;
using LL = __int128;
using mint = modint998244353;
const ll mod = 998244353;
//const ll mod = 1000000007;
typedef pair<ll, ll> pll;
typedef tuple<ll, ll, ll> tu;
using vl = vector<ll>;
using vb = vector<bool>;
using vvb = vector<vb>;
using vvl = vector<vl>;
using vs = vector<string>;
using vc = vector<char>;
using vmi = vector<mint>;
ll gcd(ll a, ll b){if(a%b == 0)return b;else return gcd(b, a%b);}//最大公約数
ll lcm(ll a, ll b){return a*b / gcd(a, b);}//最小公倍数
template<class T> inline bool chmin(T& a, T b) {if (a > b) {a = b;return true;}return false;}
template<class T> inline bool chmax(T& a, T b) {if (a < b) {a = b;return true;}return false;}
template<class T> void Uni_erase(std::vector<T>& vec) {
std::sort(vec.begin(), vec.end());
vec.erase(std::unique(vec.begin(), vec.end()), vec.end());}
map<pair<ll,ll>,ll> Pow_map;
ll Pow(ll x, ll y) {if (Pow_map.count({x, y})) return Pow_map[{x, y}];
ll res = 1, base = x;while (y > 0) {if (y & 1) res *= base;base *= base;y >>= 1;}return Pow_map[{x, y}] = res;}
ll Exp(ll x, ll y){ll cnt = -1;while(x>0){x/=y;cnt++;}return cnt;}
ll powmod(ll x, ll k, int mod){if (k == 0) return 1%mod;ll res = powmod(x,k/2,mod);res = (res*res)%mod;if (k%2 == 1) res = (res*x)%mod;return res;}
inline bool OutIn(ll x, ll y, ll height, ll width) {return 0 <= x && x < height && 0 <= y && y < width;}
std::mt19937 rng(std::random_device{}());
ll Random(ll l, ll r) {std::uniform_int_distribution<long long> dist(l, r - 1);return dist(rng);}
vl cin_vl(ll n){vl ret(n); rep(i,n) cin >> ret[i]; return ret;}
pair<vl,vl> cin_xy(ll n){vl x(n), y(n); rep(i,n) cin >> x[i] >> y[i]; return {x,y};}
vvl Cin_vl(ll n, ll k){vvl ret(k,vl(n));rep(i,n)rep(j,k) cin >> ret[j][i]; return ret;}
void cout_vl(vl a){for(auto e : a)cout << e << ' '; cout << endl;}
void Cout_vl(vl a, vl b){ll n = sz(a); rep(i,n)cout << a[i] << ' ' << b[i] << endl;}
void cout_vvl(vvl a){for(auto e : a){cout_vl(e);} cout<< endl;}
//cout << fixed << setprecision(10)
using Graph = vector<vector<pair<ll,ll>>>;
using graph = vector<vector<int>>;
//vector<vector<bool>> seen(h,vector<bool>(w,false));
//seen.assign(h, vector<bool>(w, false));
vector<int> dx = {0, 1, 0, -1};
vector<int> dy = {1, 0, -1, 0};
int main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
ll n;
cin >> n;
auto a = cin_vl(n);
vl ans(n,-1);
rrep(i,n){
if(a[i] == i+1) ans[i] = i+1;
else ans[i] = ans[a[i]-1];
}
cout_vl(ans);
}
提出情報
ジャッジ結果
| セット名 |
Sample |
All |
| 得点 / 配点 |
0 / 0 |
300 / 300 |
| 結果 |
|
|
| セット名 |
テストケース |
| Sample |
00_sample_00.txt, 00_sample_01.txt, 00_sample_02.txt |
| All |
00_sample_00.txt, 00_sample_01.txt, 00_sample_02.txt, 01_random_03.txt, 01_random_04.txt, 01_random_05.txt, 01_random_06.txt, 01_random_07.txt, 01_random_08.txt, 01_random_09.txt, 01_random_10.txt, 01_random_11.txt, 01_random_12.txt, 01_random_13.txt, 01_random_14.txt, 01_random_15.txt, 01_random_16.txt, 01_random_17.txt |
| ケース名 |
結果 |
実行時間 |
メモリ |
| 00_sample_00.txt |
AC |
1 ms |
3636 KiB |
| 00_sample_01.txt |
AC |
1 ms |
3424 KiB |
| 00_sample_02.txt |
AC |
1 ms |
3524 KiB |
| 01_random_03.txt |
AC |
38 ms |
15816 KiB |
| 01_random_04.txt |
AC |
38 ms |
15808 KiB |
| 01_random_05.txt |
AC |
38 ms |
15812 KiB |
| 01_random_06.txt |
AC |
39 ms |
15820 KiB |
| 01_random_07.txt |
AC |
40 ms |
15816 KiB |
| 01_random_08.txt |
AC |
40 ms |
15804 KiB |
| 01_random_09.txt |
AC |
39 ms |
15804 KiB |
| 01_random_10.txt |
AC |
39 ms |
15816 KiB |
| 01_random_11.txt |
AC |
16 ms |
7588 KiB |
| 01_random_12.txt |
AC |
13 ms |
7004 KiB |
| 01_random_13.txt |
AC |
35 ms |
14116 KiB |
| 01_random_14.txt |
AC |
4 ms |
4032 KiB |
| 01_random_15.txt |
AC |
39 ms |
15568 KiB |
| 01_random_16.txt |
AC |
2 ms |
3608 KiB |
| 01_random_17.txt |
AC |
38 ms |
15800 KiB |