結果
問題 | No.1097 Remainder Operation |
ユーザー |
![]() |
提出日時 | 2020-06-26 21:23:31 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 215 ms / 2,000 ms |
コード長 | 1,715 bytes |
コンパイル時間 | 1,280 ms |
コンパイル使用メモリ | 111,420 KB |
実行使用メモリ | 50,944 KB |
最終ジャッジ日時 | 2024-07-04 19:33:08 |
合計ジャッジ時間 | 5,245 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 21 |
ソースコード
#include<iostream>#include<string>#include<cstdio>#include<vector>#include<cmath>#include<algorithm>#include<functional>#include<iomanip>#include<queue>#include<ciso646>#include<random>#include<map>#include<set>#include<bitset>#include<stack>#include<unordered_map>#include<utility>#include<cassert>#include<complex>#include<numeric>using namespace std;//#define int long longtypedef long long ll;typedef unsigned long long ul;typedef unsigned int ui;//constexpr ll mod = 998244353;//const ll INF = mod * mod;typedef pair<int, int>P;#define stop char nyaa;cin>>nyaa;#define rep(i,n) for(int i=0;i<n;i++)#define per(i,n) for(int i=n-1;i>=0;i--)#define Rep(i,sta,n) for(int i=sta;i<n;i++)#define rep1(i,n) for(int i=1;i<=n;i++)#define per1(i,n) for(int i=n;i>=1;i--)#define Rep1(i,sta,n) for(int i=sta;i<=n;i++)#define all(v) (v).begin(),(v).end()typedef pair<ll, ll> LP;typedef long double ld;typedef pair<ld, ld> LDP;const ld eps = 1e-8;const ld pi = acosl(-1.0);int nex[1 << 17][40];ll cost[1 << 17][40];void solve() {int n; cin >> n;vector<ll> a(n);rep(i, n)cin >> a[i];rep(i, n) {nex[i][0] = (i + a[i]) % n;cost[i][0] = a[i];}rep(j, 39)rep(i, n) {nex[i][j + 1] = nex[nex[i][j]][j];cost[i][j + 1] = cost[i][j] + cost[nex[i][j]][j];}int q; cin >> q;rep(i, q) {ll c; cin >> c;int cur = 0;ll ans = 0;per(j, 40) {if (c&(1ll << j)) {ans += cost[cur][j];cur = nex[cur][j];}}//cout << "ans is ";cout << ans << "\n";}}signed main() {ios::sync_with_stdio(false);cin.tie(0);//cout << fixed << setprecision(7);//init_f();//init();//int t; cin >> t; rep(i, t)solve();stopreturn 0;}