結果
問題 | No.742 にゃんにゃんにゃん 猫の挨拶 |
ユーザー | itsy68 |
提出日時 | 2022-06-10 05:28:02 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 75 ms / 2,500 ms |
コード長 | 842 bytes |
コンパイル時間 | 215 ms |
コンパイル使用メモリ | 81,732 KB |
実行使用メモリ | 77,464 KB |
最終ジャッジ日時 | 2023-10-21 04:35:51 |
合計ジャッジ時間 | 2,110 ms |
ジャッジサーバーID (参考情報) |
judge15 / judge13 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 49 ms
63,520 KB |
testcase_01 | AC | 49 ms
63,520 KB |
testcase_02 | AC | 49 ms
63,520 KB |
testcase_03 | AC | 48 ms
63,520 KB |
testcase_04 | AC | 48 ms
63,520 KB |
testcase_05 | AC | 49 ms
64,012 KB |
testcase_06 | AC | 53 ms
66,084 KB |
testcase_07 | AC | 68 ms
70,836 KB |
testcase_08 | AC | 65 ms
72,896 KB |
testcase_09 | AC | 52 ms
63,520 KB |
testcase_10 | AC | 49 ms
63,520 KB |
testcase_11 | AC | 75 ms
77,464 KB |
testcase_12 | AC | 75 ms
77,452 KB |
testcase_13 | AC | 51 ms
63,520 KB |
testcase_14 | AC | 51 ms
63,520 KB |
testcase_15 | AC | 52 ms
63,520 KB |
ソースコード
# import pypyjit # pypyjit.set_param('max_unroll_recursion=-1') import sys from itertools import combinations, permutations, product, accumulate, groupby from collections import defaultdict, deque, Counter from functools import reduce from operator import add, mul import heapq import bisect import math import copy sys.setrecursionlimit(10 ** 9) input = lambda: sys.stdin.readline().rstrip() INF = float("inf") MOD = 10 ** 9 + 7 N = int(input()) A = [] for i in range(N): A.append(int(input())) # BIT data = [0]*(N+1) def add(k, x): while k <= N: data[k] += x k += k & -k def get(k): s = 0 while k: s += data[k] k -= k & -k return s ans = 0 for i, a in enumerate(A): # 自分より小さい要素がいくつ存在するかを計算 ans += (N-1-i) - get(a) add(a, 1) print(ans)