結果
| 問題 | No.854 公平なりんご分配 | 
| コンテスト | |
| ユーザー |  | 
| 提出日時 | 2019-08-01 19:24:20 | 
| 言語 | F# (F# 4.0) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 1,028 ms / 3,153 ms | 
| コード長 | 1,693 bytes | 
| コンパイル時間 | 7,091 ms | 
| コンパイル使用メモリ | 187,904 KB | 
| 実行使用メモリ | 61,044 KB | 
| 最終ジャッジ日時 | 2024-07-05 07:52:59 | 
| 合計ジャッジ時間 | 37,339 ms | 
| ジャッジサーバーID (参考情報) | judge1 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 2 | 
| other | AC * 92 | 
コンパイルメッセージ
復元対象のプロジェクトを決定しています... /home/judge/data/code/main.fsproj を復元しました (238 ms)。 MSBuild のバージョン 17.9.6+a4ecab324 (.NET) main -> /home/judge/data/code/bin/Release/net8.0/main.dll main -> /home/judge/data/code/bin/Release/net8.0/publish/
ソースコード
open System
open System.Text
open System.IO
open System.Collections.Generic
let reader = new StreamReader(new BufferedStream(Console.OpenStandardInput ()))
let read f = 
  while reader.Peek () <= int ' ' do reader.Read () |> ignore
  [|while reader.Peek () > int ' ' do yield char (reader.Read ())|] |> System.String |> f
let read_int () =
  while reader.Peek () <= int ' ' do reader.Read () |> ignore
  let mutable ans = 0
  while reader.Peek () > int ' ' do
    ans <- ans * 10 + (reader.Read () - int '0')
  ans
let N = read_int ()
let A = Array.init N (fun _ -> read_int ())
let Q = read_int ()
let P = Array.zeroCreate Q
let L = Array.zeroCreate Q
let R = Array.zeroCreate Q
let zero = Array.zeroCreate (N+1)
for i in 0..Q-1 do
  P.[i] <- read_int ()
  L.[i] <- read_int () - 1
  R.[i] <- read_int ()
for i in 0..N-1 do zero.[i+1] <- zero.[i] + (if A.[i] = 0 then 1 else 0)
for i in 0..Q-1 do if zero.[R.[i]] - zero.[L.[i]] > 0 then P.[i] <- 1
let table = Array.create 2001 true
let primes = new ResizeArray<int>()
table.[0] <- false
table.[1] <- false
for i in 2..2000 do
  if table.[i] then
    primes.Add(i)
    for j in 2*i..i..2000 do table.[j] <- false
let ans = Array.create Q true
for p in primes do
  let cnt = Array.zeroCreate (N+1)
  for i in 0..N-1 do
    let mutable k = 0
    while A.[i] <> 0 && A.[i] % p = 0 do
      A.[i] <- A.[i] / p
      k <- k + 1
    cnt.[i+1] <- cnt.[i] + k
  for i in 0..Q-1 do
    let mutable k = 0
    while P.[i] % p = 0 do
      P.[i] <- P.[i] / p
      k <- k + 1
    if cnt.[R.[i]] - cnt.[L.[i]] < k then
      ans.[i] <- false
for i in 0..Q-1 do
  if P.[i] <> 1 then ans.[i] <- false
  printfn "%s" (if ans.[i] then "Yes" else "NO")
            
            
            
        