結果
| 問題 | 
                            No.358 も~っと!門松列
                             | 
                    
| コンテスト | |
| ユーザー | 
                             | 
                    
| 提出日時 | 2017-01-05 16:11:29 | 
| 言語 | Python3  (3.13.1 + numpy 2.2.1 + scipy 1.14.1)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 32 ms / 1,000 ms | 
| コード長 | 821 bytes | 
| コンパイル時間 | 294 ms | 
| コンパイル使用メモリ | 12,544 KB | 
| 実行使用メモリ | 10,752 KB | 
| 最終ジャッジ日時 | 2024-12-16 09:28:32 | 
| 合計ジャッジ時間 | 2,011 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge4 / judge1 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 23 | 
ソースコード
# yukicoder No.358 も~っと!門松列
# 門松列判定関数
def is_kadomatu(a):
    if (a[0] - a[1]) * (a[2] - a[1]) > 0 and a[0] != a[2]:
        return True
    else:
        return False
# 入力
A = [int(i) for i in input().split()]
# 処理
if is_kadomatu(A): # Aが門松列なら無限にある
    print("INF")
elif len(set(A)) < 3: # Aの中に同じ要素があるならB_pに門松列は無い
    print(0)
else: # Aは門松列でなく、かつ全ての要素が異なるとき
    M = max(A) 
    count = 0
    # Mより大きい数をpにしたとき、B_pはAに等しくなり、それは全て門松列ではない
    # 故に確かめるのはMまででよい
    for p in range(1, M + 1):
        B = [a % p for a in A]
        if is_kadomatu(B):
            count += 1
    print(count)