結果

問題 No.1034 テスターのふっぴーさん
ユーザー SugihaM
提出日時 2020-04-25 00:37:02
言語 Go
(1.23.4)
結果
AC  
実行時間 2 ms / 2,000 ms
コード長 1,089 bytes
コンパイル時間 12,532 ms
コンパイル使用メモリ 238,216 KB
実行使用メモリ 6,816 KB
最終ジャッジ日時 2024-10-15 04:03:39
合計ジャッジ時間 13,372 ms
ジャッジサーバーID
(参考情報)
judge4 / judge5
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 30
権限があれば一括ダウンロードができます

ソースコード

diff #

package main

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

var sc = bufio.NewScanner(os.Stdin)

func Scanner() string {
	sc.Scan()
	return sc.Text()
}
func main() {
	buf := make([]byte, 0)
	sc.Buffer(buf, 100000007)
	sc.Split(bufio.ScanWords)
	q, _ := strconv.Atoi(Scanner())
	for i := 0; i < q; i++ {
		n, _ := strconv.Atoi(Scanner())
		i, _ := strconv.Atoi(Scanner())
		j, _ := strconv.Atoi(Scanner())
		ans := n*n - (n-2*min(i, j, n-1-i, n-1-j))*(n-2*min(i, j, n-1-i, n-1-j))
		n, i, j = n-2*min(i, j, n-1-i, n-1-j), i-min(i, j, n-1-i, n-1-j), j-min(i, j, n-1-i, n-1-j)
		if i == 0 {
			ans += j
		} else if j == n-1 {
			ans += n - 1 + i
		} else if i == n-1 {
			ans += 2*(n-1) + (n - 1) - j
		} else if j == 0 {
			ans += 3*(n-1) + (n - 1) - i
		}
		fmt.Println(ans)
	}
}

func min(a int, b int, c int, d int) int {
	if a < b {
		if a < c {
			if a < d {
				return a
			} else {
				return d
			}
		} else if c < d {
			return c
		} else {
			return d
		}
	} else if b < c {
		if b < d {
			return b
		} else {
			return d
		}
	} else if c < d {
		return c
	} else {
		return d
	}
}
0