結果
| 問題 |
No.617 Nafmo、買い出しに行く
|
| コンテスト | |
| ユーザー |
tsuchinaga
|
| 提出日時 | 2019-02-28 12:20:05 |
| 言語 | Go (1.23.4) |
| 結果 |
AC
|
| 実行時間 | 594 ms / 2,000 ms |
| コード長 | 647 bytes |
| コンパイル時間 | 15,287 ms |
| コンパイル使用メモリ | 237,580 KB |
| 実行使用メモリ | 8,096 KB |
| 最終ジャッジ日時 | 2024-06-23 11:36:41 |
| 合計ジャッジ時間 | 19,739 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 2 |
| other | AC * 20 |
ソースコード
package main
import (
"fmt"
"math"
"sort"
"strconv"
)
func main() {
var n, k, a int
_, _ = fmt.Scan(&n, &k)
nums := make([]int, 0)
for i := 0; i < n; i++ {
_, _ = fmt.Scan(&a)
if a <= k {
nums = append(nums, a)
}
}
sort.Slice(nums, func(i, j int) bool {
return nums[i] > nums[j]
})
max := 0
for i := 1; i < int(math.Pow(float64(2), float64(len(nums)))); i++ {
b := fmt.Sprintf("%0"+strconv.Itoa(len(nums))+"b\n", i)
sum := 0
for i, v := range []rune(b) {
if string(v) == "1" {
sum += nums[i]
if sum > k {
break
}
}
}
if sum <= k && max < sum {
max = sum
}
}
fmt.Println(max)
}
tsuchinaga