Submission #7062316


Source Code Expand

package main

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

func getScanner(fp *os.File) *bufio.Scanner {
	scanner := bufio.NewScanner(fp)
	scanner.Split(bufio.ScanWords)
	scanner.Buffer(make([]byte, 500001), 500000)
	return scanner
}

func getNextString(scanner *bufio.Scanner) string {
	scanner.Scan()
	return scanner.Text()
}

func getNextInt(scanner *bufio.Scanner) int {
	i, _ := strconv.Atoi(getNextString(scanner))
	return i
}

func getNextInt64(scanner *bufio.Scanner) int64 {
	i, _ := strconv.ParseInt(getNextString(scanner), 10, 64)
	return i
}

func getNextUint64(scanner *bufio.Scanner) uint64 {
	i, _ := strconv.ParseUint(getNextString(scanner), 10, 64)
	return i
}

func getNextFloat64(scanner *bufio.Scanner) float64 {
	i, _ := strconv.ParseFloat(getNextString(scanner), 64)
	return i
}

func main() {
	fp := os.Stdin
	if len(os.Args) > 1 {
		fp, _ = os.Open(os.Args[1])
	}

	scanner := getScanner(fp)
	writer := bufio.NewWriter(os.Stdout)

	r := getNextInt(scanner)
	g := getNextInt(scanner)
	b := getNextInt(scanner)

	min := math.MaxInt32
	for ri := -450; ri <= 450-r-g-b; ri++ {
		for gi := ri + r; gi <= 450-g-b; gi++ {
			bi := maxint(gi+g, 100-(b-1)>>1)
			sum := move(-100, ri, ri+r-1) + move(0, gi, gi+g-1) + move(100, bi, bi+b-1)
			if min > sum {
				min = sum
			}
		}
	}

	fmt.Fprintln(writer, min)

	writer.Flush()
}

func move(i, s, t int) int {
	if s < i && i < t {
		return (i-s+1)*(i-s)/2 + (t-i+1)*(t-i)/2
	}
	return (absint(s-i) + absint(t-i)) * (t - s + 1) / 2
}

func absint(a int) int {
	if a < 0 {
		return -a
	}
	return a
}
func maxint(a int, b int) int {
	if a > b {
		return a
	}
	return b
}

Submission Info

Submission Time
Task D - マーブル
User ccppjsrb
Language Go (1.6)
Score 100
Code Size 1731 Byte
Status AC
Exec Time 7 ms
Memory 640 KB

Judge Result

Set Name sub1 sub2 All
Score / Max Score 10 / 10 30 / 30 60 / 60
Status
AC × 29
AC × 57
AC × 85
Set Name Test Cases
sub1 sample_01_ABC.txt, test_ABC_01.txt, test_ABC_02.txt, test_ABC_03.txt, test_ABC_04.txt, test_ABC_05.txt, test_ABC_06.txt, test_ABC_07.txt, test_ABC_08.txt, test_ABC_09.txt, test_ABC_10.txt, test_ABC_11.txt, test_ABC_12.txt, test_ABC_13.txt, test_ABC_14.txt, test_ABC_15.txt, test_ABC_16.txt, test_ABC_17.txt, test_ABC_18.txt, test_ABC_19.txt, test_ABC_20.txt, test_ABC_21.txt, test_ABC_22.txt, test_ABC_23.txt, test_ABC_24.txt, test_ABC_25.txt, test_ABC_26.txt, test_ABC_27.txt, test_ABC_28.txt
sub2 sample_01_ABC.txt, sample_02_BC.txt, test_ABC_01.txt, test_ABC_02.txt, test_ABC_03.txt, test_ABC_04.txt, test_ABC_05.txt, test_ABC_06.txt, test_ABC_07.txt, test_ABC_08.txt, test_ABC_09.txt, test_ABC_10.txt, test_ABC_11.txt, test_ABC_12.txt, test_ABC_13.txt, test_ABC_14.txt, test_ABC_15.txt, test_ABC_16.txt, test_ABC_17.txt, test_ABC_18.txt, test_ABC_19.txt, test_ABC_20.txt, test_ABC_21.txt, test_ABC_22.txt, test_ABC_23.txt, test_ABC_24.txt, test_ABC_25.txt, test_ABC_26.txt, test_ABC_27.txt, test_ABC_28.txt, test_BC_29.txt, test_BC_30.txt, test_BC_31.txt, test_BC_32.txt, test_BC_33.txt, test_BC_34.txt, test_BC_35.txt, test_BC_36.txt, test_BC_37.txt, test_BC_38.txt, test_BC_39.txt, test_BC_40.txt, test_BC_41.txt, test_BC_42.txt, test_BC_43.txt, test_BC_44.txt, test_BC_45.txt, test_BC_46.txt, test_BC_47.txt, test_BC_48.txt, test_BC_49.txt, test_BC_50.txt, test_BC_51.txt, test_BC_52.txt, test_BC_53.txt, test_BC_54.txt, test_BC_55.txt
All sample_01_ABC.txt, sample_02_BC.txt, sample_03_C.txt, test_ABC_01.txt, test_ABC_02.txt, test_ABC_03.txt, test_ABC_04.txt, test_ABC_05.txt, test_ABC_06.txt, test_ABC_07.txt, test_ABC_08.txt, test_ABC_09.txt, test_ABC_10.txt, test_ABC_11.txt, test_ABC_12.txt, test_ABC_13.txt, test_ABC_14.txt, test_ABC_15.txt, test_ABC_16.txt, test_ABC_17.txt, test_ABC_18.txt, test_ABC_19.txt, test_ABC_20.txt, test_ABC_21.txt, test_ABC_22.txt, test_ABC_23.txt, test_ABC_24.txt, test_ABC_25.txt, test_ABC_26.txt, test_ABC_27.txt, test_ABC_28.txt, test_BC_29.txt, test_BC_30.txt, test_BC_31.txt, test_BC_32.txt, test_BC_33.txt, test_BC_34.txt, test_BC_35.txt, test_BC_36.txt, test_BC_37.txt, test_BC_38.txt, test_BC_39.txt, test_BC_40.txt, test_BC_41.txt, test_BC_42.txt, test_BC_43.txt, test_BC_44.txt, test_BC_45.txt, test_BC_46.txt, test_BC_47.txt, test_BC_48.txt, test_BC_49.txt, test_BC_50.txt, test_BC_51.txt, test_BC_52.txt, test_BC_53.txt, test_BC_54.txt, test_BC_55.txt, test_C_56.txt, test_C_57.txt, test_C_58.txt, test_C_59.txt, test_C_60.txt, test_C_61.txt, test_C_62.txt, test_C_63.txt, test_C_64.txt, test_C_65.txt, test_C_66.txt, test_C_67.txt, test_C_68.txt, test_C_69.txt, test_C_70.txt, test_C_71.txt, test_C_72.txt, test_C_73.txt, test_C_74.txt, test_C_75.txt, test_C_76.txt, test_C_77.txt, test_C_78.txt, test_C_79.txt, test_C_80.txt, test_C_81.txt, test_C_82.txt
Case Name Status Exec Time Memory
sample_01_ABC.txt AC 7 ms 640 KB
sample_02_BC.txt AC 6 ms 640 KB
sample_03_C.txt AC 1 ms 640 KB
test_ABC_01.txt AC 7 ms 640 KB
test_ABC_02.txt AC 7 ms 640 KB
test_ABC_03.txt AC 7 ms 640 KB
test_ABC_04.txt AC 7 ms 640 KB
test_ABC_05.txt AC 7 ms 640 KB
test_ABC_06.txt AC 7 ms 640 KB
test_ABC_07.txt AC 7 ms 640 KB
test_ABC_08.txt AC 7 ms 640 KB
test_ABC_09.txt AC 7 ms 640 KB
test_ABC_10.txt AC 7 ms 640 KB
test_ABC_11.txt AC 6 ms 640 KB
test_ABC_12.txt AC 7 ms 640 KB
test_ABC_13.txt AC 7 ms 640 KB
test_ABC_14.txt AC 7 ms 640 KB
test_ABC_15.txt AC 7 ms 640 KB
test_ABC_16.txt AC 7 ms 640 KB
test_ABC_17.txt AC 7 ms 640 KB
test_ABC_18.txt AC 6 ms 640 KB
test_ABC_19.txt AC 7 ms 640 KB
test_ABC_20.txt AC 7 ms 640 KB
test_ABC_21.txt AC 7 ms 640 KB
test_ABC_22.txt AC 7 ms 640 KB
test_ABC_23.txt AC 7 ms 640 KB
test_ABC_24.txt AC 7 ms 640 KB
test_ABC_25.txt AC 7 ms 640 KB
test_ABC_26.txt AC 7 ms 640 KB
test_ABC_27.txt AC 7 ms 640 KB
test_ABC_28.txt AC 6 ms 640 KB
test_BC_29.txt AC 6 ms 640 KB
test_BC_30.txt AC 6 ms 640 KB
test_BC_31.txt AC 6 ms 640 KB
test_BC_32.txt AC 6 ms 640 KB
test_BC_33.txt AC 6 ms 640 KB
test_BC_34.txt AC 6 ms 640 KB
test_BC_35.txt AC 6 ms 640 KB
test_BC_36.txt AC 6 ms 640 KB
test_BC_37.txt AC 6 ms 640 KB
test_BC_38.txt AC 6 ms 640 KB
test_BC_39.txt AC 6 ms 640 KB
test_BC_40.txt AC 6 ms 640 KB
test_BC_41.txt AC 6 ms 640 KB
test_BC_42.txt AC 6 ms 640 KB
test_BC_43.txt AC 6 ms 640 KB
test_BC_44.txt AC 6 ms 640 KB
test_BC_45.txt AC 6 ms 640 KB
test_BC_46.txt AC 6 ms 640 KB
test_BC_47.txt AC 6 ms 640 KB
test_BC_48.txt AC 6 ms 640 KB
test_BC_49.txt AC 6 ms 640 KB
test_BC_50.txt AC 6 ms 640 KB
test_BC_51.txt AC 6 ms 640 KB
test_BC_52.txt AC 6 ms 640 KB
test_BC_53.txt AC 6 ms 640 KB
test_BC_54.txt AC 6 ms 640 KB
test_BC_55.txt AC 5 ms 640 KB
test_C_56.txt AC 4 ms 640 KB
test_C_57.txt AC 2 ms 640 KB
test_C_58.txt AC 2 ms 640 KB
test_C_59.txt AC 3 ms 640 KB
test_C_60.txt AC 4 ms 640 KB
test_C_61.txt AC 3 ms 640 KB
test_C_62.txt AC 3 ms 640 KB
test_C_63.txt AC 3 ms 640 KB
test_C_64.txt AC 3 ms 640 KB
test_C_65.txt AC 3 ms 640 KB
test_C_66.txt AC 3 ms 640 KB
test_C_67.txt AC 2 ms 640 KB
test_C_68.txt AC 4 ms 640 KB
test_C_69.txt AC 4 ms 640 KB
test_C_70.txt AC 3 ms 640 KB
test_C_71.txt AC 2 ms 640 KB
test_C_72.txt AC 1 ms 640 KB
test_C_73.txt AC 2 ms 640 KB
test_C_74.txt AC 2 ms 640 KB
test_C_75.txt AC 3 ms 640 KB
test_C_76.txt AC 2 ms 640 KB
test_C_77.txt AC 2 ms 640 KB
test_C_78.txt AC 2 ms 640 KB
test_C_79.txt AC 3 ms 640 KB
test_C_80.txt AC 3 ms 640 KB
test_C_81.txt AC 4 ms 640 KB
test_C_82.txt AC 1 ms 640 KB