結果
問題 | No.742 にゃんにゃんにゃん 猫の挨拶 |
ユーザー |
|
提出日時 | 2018-10-05 22:17:46 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 6 ms / 2,500 ms |
コード長 | 918 bytes |
コンパイル時間 | 771 ms |
コンパイル使用メモリ | 85,220 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-11-15 19:05:22 |
合計ジャッジ時間 | 1,700 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 16 |
ソースコード
#include <limits>#include <iostream>#include <algorithm>#include <vector>#include <iomanip>#include <map>#include <queue>static const int MOD = 1000000007;using ll = long long;using u32 = unsigned;using namespace std;template<class T>constexpr T INF = ::numeric_limits<T>::max() / 32 * 15 + 208;template<class T>class BIT {vector<T> bit;public:BIT(int n): bit(vector<T>(n+1, 0)){}T sum(int k){T ret = 0;for (++k; k > 0; k -= (k & -k)) ret += bit[k];return ret;}void add(int k, T x){for (++k; k < bit.size(); k += (k & -k)) bit[k] += x;}};int main() {int n;cin >> n;vector<int> v(n);BIT<int> bit(n+1);for (auto &&i : v) scanf("%d", &i);ll ans = 0;for (int i = 0; i < n; ++i) {ans += bit.sum(n)-bit.sum(v[i]);bit.add(v[i], 1);}cout << ans << "\n";return 0;}