Go 言語で「基礎プログラミング演習 I 〜100 本ノック中級編」を解いてみる-No.42「小さい順?」

はじめに

「基礎プログラミング演習 I 〜100 本ノック中級編」を解いてみます。

取り扱う問題は以下のサイトを引用させていただきました。

検証環境

$ uname -moi
x86_64 unknown GNU/Linux

$ head -n 2 /etc/os-release
PRETTY_NAME="Debian GNU/Linux 10 (buster)"
NAME="Debian GNU/Linux"

$ go version | head -n 1
go version go1.16.3 linux/amd64

問題

No. 42 小さい順?

整数値を 3 つ入力させ、それらの値が小さい順(等しくてもよい)に並んでいるか判定し、小さい順に並んでいる場合は OK、そうなっていない場合は NG と表示するプログラムを作成せよ。

# 【実行例、下線部は入力例】
$ ./knock42
input number 1: 1
input number 2: 2
input number 3: 3
OK

$ ./knock42
input number 1: 1
input number 2: 1
input number 3: 3
OK

$ ./knock42
input number 1: 2
input number 2: 1
input number 3: 3
NG

回答

knock42.go

package main

import (
    "fmt"
    "sort"
)

func main() {
    nums := make([]int, 3)

    for i := 0; i < 3; i++ {
        fmt.Printf("input number %v: ", i+1)
        fmt.Scan(&nums[i])
    }

    if sort.SliceIsSorted(nums, func(i, j int) bool { return nums[j]-nums[i] > 0 }) {
        fmt.Println("OK")
    } else {
        fmt.Println("NG")
    }
}

実行

$ go run knock42.go
input number 1: 1
input number 2: 2
input number 3: 3
OK

$ go run knock42.go
input number 1: 1
input number 2: 1
input number 3: 3
OK

$ go run knock42.go
input number 1: 2
input number 2: 1
input number 3: 3
NG

ひとこと

sort パッケージに SliceIsSorted という、ソート済みかどうかをチェックするズバリな件数が用意されていました。便利!

Posted by genzouw