結果

問題 No.1440 The Quiz Competition
ユーザー ccppjsrbccppjsrb
提出日時 2021-03-26 23:17:00
言語 Go
(1.22.1)
結果
WA  
実行時間 -
コード長 2,367 bytes
コンパイル時間 12,063 ms
コンパイル使用メモリ 224,316 KB
実行使用メモリ 5,376 KB
最終ジャッジ日時 2024-05-06 17:19:22
合計ジャッジ時間 13,032 ms
ジャッジサーバーID
(参考情報)
judge3 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 1 ms
5,248 KB
testcase_01 WA -
testcase_02 WA -
testcase_03 WA -
testcase_04 WA -
testcase_05 WA -
testcase_06 WA -
testcase_07 WA -
testcase_08 WA -
testcase_09 WA -
testcase_10 WA -
testcase_11 WA -
testcase_12 WA -
testcase_13 WA -
testcase_14 WA -
testcase_15 WA -
testcase_16 WA -
testcase_17 WA -
testcase_18 WA -
testcase_19 WA -
testcase_20 WA -
testcase_21 WA -
testcase_22 WA -
testcase_23 WA -
testcase_24 WA -
testcase_25 WA -
testcase_26 WA -
testcase_27 WA -
権限があれば一括ダウンロードができます

ソースコード

diff #

package main

import (
	"bufio"
	"fmt"
	"os"
	"strconv"
)

func getNextString(scanner *bufio.Scanner) string {
	if !scanner.Scan() {
		panic("scan failed")
	}
	return scanner.Text()
}
func atoi(s string) int                             { x, _ := strconv.Atoi(s); return x }
func getNextInt(scanner *bufio.Scanner) int         { return atoi(getNextString(scanner)) }
func atoi64(s string) int64                         { x, _ := strconv.ParseInt(s, 10, 64); return x }
func getNextInt64(scanner *bufio.Scanner) int64     { return atoi64(getNextString(scanner)) }
func atof64(s string) float64                       { x, _ := strconv.ParseFloat(s, 64); return x }
func getNextFloat64(scanner *bufio.Scanner) float64 { return atof64(getNextString(scanner)) }
func main() {
	fp := os.Stdin
	wfp := os.Stdout
	extra := 0
	if os.Getenv("I") == "IronMan" {
		fp, _ = os.Open(os.Getenv("END_GAME"))
		extra = 100
	}
	scanner := bufio.NewScanner(fp)
	scanner.Split(bufio.ScanWords)
	scanner.Buffer(make([]byte, 1000005), 1000005)
	writer := bufio.NewWriter(wfp)
	defer func() {
		r := recover()
		if r != nil {
			fmt.Fprintln(writer, r)
		}
		writer.Flush()
	}()
	solve(scanner, writer)
	for i := 0; i < extra; i++ {
		fmt.Fprintln(writer, "-----------------------------------")
		solve(scanner, writer)
	}
}

const Inf = 1000_000_000_000_000_000

func solve(scanner *bufio.Scanner, writer *bufio.Writer) {
	t := getNextInt(scanner)
	for t > 0 {
		t--
		func() {
			n := getNextInt(scanner)
			a := getNextInt(scanner)
			w := getNextInt(scanner)
			k := getNextInt(scanner)
			if n == k {
				ww := make([]int, n)
				for i := 0; i < n; i++ {
					ww[i] += w / n
				}
				w %= n
				for i := 0; i < w; i++ {
					ww[i]++
				}
				for i := 1; i < w; i++ {
					a--
				}
				for i := 0; i < n-1; i++ {
					if ww[i] != ww[i+1] && i <= a {
						fmt.Fprintln(writer, -ww[0]*(ww[0]+1)/2+a/n)
						return
					}
				}
				ww[0]++
				fmt.Fprintln(writer, -ww[0]*(ww[0]+1)/2+a/n)
				return
			}
			l := -1
			r := Inf
			for l+1 < r {
				m := (l + r) >> 1
				if (m+1)*(k-1)+m > a {
					r = m
					continue
				}
				l = m
			}
			if l < 0 {
				fmt.Fprintln(writer, ":(")
				return
			}
			fmt.Fprintln(writer, l)
		}()
	}
}
func bf(md int) int {
	l := -1
	r := Inf
	for l+1 < r {
		m := (l + r) >> 1
		if m*(m+1)/2 < md {
			l = m
			continue
		}
		r = m
	}
	return r
}
0