結果
| 問題 | 
                            No.33 アメーバがたくさん
                             | 
                    
| コンテスト | |
| ユーザー | 
                             sasa8uyauya
                         | 
                    
| 提出日時 | 2024-12-06 23:37:40 | 
| 言語 | PyPy3  (7.3.15)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 39 ms / 5,000 ms | 
| コード長 | 437 bytes | 
| コンパイル時間 | 349 ms | 
| コンパイル使用メモリ | 82,128 KB | 
| 実行使用メモリ | 52,352 KB | 
| 最終ジャッジ日時 | 2024-12-06 23:37:43 | 
| 合計ジャッジ時間 | 1,619 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge4 / judge3 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 11 | 
ソースコード
n,D,T=map(int,input().split())
x=list(map(int,input().split()))
x.sort()
r={}
for v in x:
  if v%D not in r:
    r[v%D]=[]
  r[v%D]+=[(v-(v%D))//D]
c=0
for i in r:
  z=[]
  for v in r[i]:
    z+=[v-T,v+T+1]
  z=sorted(set(z))
  d={v:j for j,v in enumerate(z)}
  q=[0]*len(z)
  for v in r[i]:
    q[d[v-T]]+=1
    q[d[v+T+1]]-=1
  for j in range(1,len(q)):
    q[j]+=q[j-1]
  c+=sum(z[j+1]-z[j] for j in range(len(q)) if q[j]!=0)
print(c)
            
            
            
        
            
sasa8uyauya