結果
問題 | No.1343 Dividing Digit |
ユーザー | mmn15277198 |
提出日時 | 2021-01-16 20:51:53 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 27 ms / 2,000 ms |
コード長 | 1,027 bytes |
コンパイル時間 | 826 ms |
コンパイル使用メモリ | 96,168 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-11-28 02:57:30 |
合計ジャッジ時間 | 2,153 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 22 |
ソースコード
#include <iostream> #include <stdio.h> #include <stdlib.h> #include <string.h> #include <algorithm> #include <vector> #include <math.h> #include <iomanip> #include <stack> #include <queue> #include <set> #include <map> using namespace std; using ll = long long; using ull = unsigned long long; using ld = long double; using pint = pair<int , int>; //const ll mod = 1000000007; const ll mod = 998244353; const ld pi = 3.14159265358979; long long gcd(long long a,long long b){ if(a < b)swap(a , b); if(a == 0 || b == 0)return a; if(a % b == 0)return b; else return gcd(b , a%b); } int main() { //ios::sync_with_stdio(false); //cin.tie(0); //cout << fixed << setprecision(15); int n , k; cin >> n >> k; vector<int> a(n); ll sum = 0; for(int i = 0; i < n; i++){ cin >> a[i]; sum += a[i]; } reverse(a.begin() , a.end()); ll ans = 0; ll kk = 1; for(int i = 0; i < n; i++){ if(i >= 1)kk *= k; kk %= sum; ans += kk * a[i]; ans %= sum; } cout << ans << endl; return 0; }