paizaの練習問題を解く クラスの継承 Go編

こんにちは、ナナオです。 前回に引き続き競プロを実施していきたいと思います。 今回の問題は以下です。 クラスの継承 | レベルアップ問題集 | プログラミング学習サイト【paizaラーニング】 実装 以下のように実装しました。 package main import "fmt" type Customer interface { OrderAlCohol(amount int) OrderSoftdrink(amount int) OrderFood(amount int) GetTotalAmount() int } type Children struct { TotalAmount int } func (c *Children) OrderAlCohol(amount int) { return } func (c *Children) OrderSoftdrink(amount int) { c.TotalAmount += amount } func (c *Children) OrderFood(amount int) { c.TotalAmount += amount } func (c *Children) GetTotalAmount() int { return c.TotalAmount } type Adult struct { Children HasOrderedAlcohol bool } func (a *Adult) OrderAlCohol(amount int) { a.TotalAmount += amount a.HasOrderedAlcohol = true } func (a *Adult) OrderSoftdrink(amount int) { a.TotalAmount += amount } func (a *Adult) OrderFood(amount int) { if a.HasOrderedAlcohol { a.TotalAmount += amount - 200 } else { a.TotalAmount += amount } } func main(){ var n, k int fmt.Scan(&n, &k) var c []Customer for i := 0; i < n; i++ { var age int fmt.Scan(&age) if age >= 20 { c = append(c, &Adult{ Children: Children{TotalAmount: 0}, HasOrderedAlcohol: false, }) } else { c = append(c, &Children{TotalAmount: 0}) } } for i := 0; i < k; i++ { var s, amount int var o string fmt.Scan(&s, &o, &amount) if o == "alcohol" { c[s - 1].OrderAlCohol(amount) } else if o == "softdrink" { c[s - 1].OrderSoftdrink(amount) } else if o == "food" { c[s - 1].OrderFood(amount) } } for i := 0; i < n; i++ { fmt.Println(c[i].GetTotalAmount()) } } Goの場合継承が通じないのでインターフェースを定義することで解決しました。 ...

2026年5月26日 · にあえん

paizaの練習問題を解く クラスのメンバの更新 Go編

こんにちは、ナナオです。 前回に引き続き競プロを実施していきたいと思います。 今回の問題は以下です。 クラスのメンバの更新 | レベルアップ問題集 | プログラミング学習サイト【paizaラーニング】 実装 以下のように実装しました。 package main import "fmt" type Emplpyee struct { number int name string } func NewEmployee(number int, name string) *Emplpyee { return &Emplpyee{ number: number, name: name, } } func (e Emplpyee) GetNum() int { return e.number } func (e Emplpyee) GetName() string { return e.name } func (e *Emplpyee) ChangeNum(number int) { e.number = number } func (e *Emplpyee) ChangeName(name string) { e.name = name } func main(){ var n int fmt.Scan(&n) var es []Emplpyee for i := 0; i < n; i++ { var cmd string fmt.Scan(&cmd) if cmd == "make" { var number int var name string fmt.Scan(&number, &name) es = append(es, *NewEmployee(number, name)) } else if cmd == "getnum" { var j int fmt.Scan(&j) fmt.Println(es[j - 1].GetNum()) } else if cmd == "getname" { var j int fmt.Scan(&j) fmt.Println(es[j - 1].GetName()) } else if cmd == "change_num" { var j, num int fmt.Scan(&j, &num) es[j - 1].ChangeNum(num) } else if cmd == "change_name" { var j int var name string fmt.Scan(&j, &name) es[j - 1].ChangeName(name) } } } 前回のコードにセッターを追加しました。 ...

2026年5月25日 · にあえん

paizaの練習問題を解く コンストラクタ Go編

こんにちは、ナナオです。 前回に引き続き競プロを実施していきたいと思います。 今回の問題は以下です。 コンストラクタ | レベルアップ問題集 | プログラミング学習サイト【paizaラーニング】 実装 以下のように実装しました。 package main import "fmt" type Emplpyee struct { number int name string } func NewEmployee(number int, name string) *Emplpyee { return &Emplpyee{ number: number, name: name, } } func (e Emplpyee) GetNum() int { return e.number } func (e Emplpyee) GetName() string { return e.name } func main(){ var n int fmt.Scan(&n) var es []Emplpyee for i := 0; i < n; i++ { var cmd string fmt.Scan(&cmd) if cmd == "make" { var number int var name string fmt.Scan(&number, &name) es = append(es, *NewEmployee(number, name)) } else if cmd == "getnum" { var j int fmt.Scan(&j) fmt.Println(es[j - 1].GetNum()) } else if cmd == "getname" { var j int fmt.Scan(&j) fmt.Println(es[j - 1].GetName()) } } } 前回と少し異なるのは、コンストラクタ(NewEmployee)を実装したところです。 ...

2026年5月24日 · にあえん

paizaの練習問題を解く クラスの作成 Go編

こんにちは、ナナオです。 前回に引き続き競プロを実施していきたいと思います。 今回の問題は以下です。 クラスの作成 | レベルアップ問題集 | プログラミング学習サイト【paizaラーニング】 実装 以下のように実装しました。 package main import "fmt" type Employee struct { number int name string } func (e Employee) GetNumber() int { return e.number } func (e Employee) GetName() string { return e.name } func main(){ var n int fmt.Scan(&n) var es []Employee for i := 0; i < n; i++ { var c string fmt.Scan(&c) if c == "make" { var e Employee fmt.Scan(&e.number, &e.name) es = append(es, e) } else if c == "getname" { var ind int fmt.Scan(&ind) fmt.Println(es[ind - 1].GetName()) } else if c == "getnum" { var ind int fmt.Scan(&ind) fmt.Println(es[ind - 1].GetNumber()) } } } ゲッターを実装するだけなので簡単ですね。 ということで今回はこれで👍

2026年5月23日 · にあえん

paizaの練習問題を解く 構造体の更新 Go編

こんにちは、ナナオです。 前回に引き続き競プロを実施していきたいと思います。 今回の問題は以下です。 構造体の更新 | レベルアップ問題集 | プログラミング学習サイト【paizaラーニング】 実装 以下のように実装しました。 package main import "fmt" type User struct { nickname string old int birth string state string } func (u *User) ChangeName(nickname string) { u.nickname = nickname } func (u User) Printf() { fmt.Printf("%s %d %s %s\n", u.nickname, u.old, u.birth, u.state) } func main(){ var n, k int fmt.Scan(&n, &k) u := make([]User, n) for i := 0; i < n; i++ { fmt.Scan(&u[i].nickname, &u[i].old, &u[i].birth, &u[i].state) } for i := 0; i < k; i++ { var m int var nn string fmt.Scan(&m, &nn) u[m - 1].ChangeName(nn) } for i := 0; i < n; i++ { u[i].Printf() } } goのセッター実装は初めてだったのでよくわかりませんでしたが、ポインタレシーバをつければいいだけでしたね。 ということで今回はこれで👍

2026年5月22日 · にあえん

paizaの練習問題を解く 構造体の整列 Go編

こんにちは、ナナオです。 前回に引き続き競プロを実施していきたいと思います。 今回の問題は以下です。 構造体の整列 | レベルアップ問題集 | プログラミング学習サイト【paizaラーニング】 実装 以下のように実装しました。 package main import ( "fmt" "sort" ) type User struct { nickname string old int birth string state string } func (u User) Printf() { fmt.Printf("%s %d %s %s\n", u.nickname, u.old, u.birth, u.state) } func main(){ var n int fmt.Scan(&n) u := make([]User, n) for i := 0; i < n; i++ { fmt.Scan(&u[i].nickname, &u[i].old, &u[i].birth, &u[i].state) } sort.Slice(u, func(i, j int) bool { return u[i].old < u[j].old }) for _, v := range u { v.Printf() } } sortパッケージを使うと楽に実装できますね。 ということで今回はこれで👍

2026年5月21日 · にあえん

paizaの練習問題を解く 構造体の検索 Go編

こんにちは、ナナオです。 前回に引き続き競プロを実施していきたいと思います。 今回の問題は以下です。 構造体の検索 | レベルアップ問題集 | プログラミング学習サイト【paizaラーニング】 実装 以下のように実装しました。 package main import "fmt" type Student struct { name string old int birth string state string } func main(){ var n, k int fmt.Scan(&n) s := make([]Student, n) for i := 0; i < n; i++ { fmt.Scan(&s[i].name, &s[i].old, &s[i].birth, &s[i].state) } fmt.Scan(&k) for i := 0; i < n; i++ { if s[i].old == k { fmt.Println(s[i].name) return } } } 普通に全探索で実装しました。 まぁ通ったのでいいでしょう。 ということで今回はこれで👍

2026年5月20日 · にあえん

paizaの練習問題を解く 構造体の作成 Go編

こんにちは、ナナオです。 前回に引き続き競プロを実施していきたいと思います。 今回の問題は以下です。 構造体の作成 | レベルアップ問題集 | プログラミング学習サイト【paizaラーニング】 実装 以下のように実装しました。 package main import "fmt" type User struct { nickname string old int birth string state string } func (u *User) Scan() { fmt.Scan(&u.nickname, &u.old, &u.birth, &u.state) } func (u *User) Printf() { fmt.Printf(`User{ nickname : %s old : %d birth : %s state : %s } `, u.nickname, u.old, u.birth, u.state) } func main(){ var n int fmt.Scan(&n) users := make([]User, n) for i := 0; i < n; i++ { users[i].Scan() } for _, u := range users { u.Printf() } } ScanとPrintfをUserのメソッドとして定義しました。 これですっきり実装できましたね。 ということで今回はこれで👍

2026年5月19日 · にあえん

paizaの練習問題を解く 数の並び替え Go編

こんにちは、ナナオです。 前回に引き続き競プロを実施していきたいと思います。 今回の問題は以下です。 数の並び替え | レベルアップ問題集 | プログラミング学習サイト【paizaラーニング】 実装 “sort"パッケージを使えば楽に実装できます。 package main import ( "fmt" "sort" ) func main(){ var n int fmt.Scan(&n) a := make([]int, n) for i := 0; i < n; i++ { fmt.Scan(&a[i]) } sort.Ints(a) for _, v := range a { fmt.Println(v) } } ソートアルゴリズム、いろいろありますが、最初から実装することないですからね。。 では今回はこれで👍

2026年5月18日 · にあえん

シンプルなdiffツール meld

こんにちは、ナナオです。 今回はdiffツールのmeldを触ります。 インストール Windowsの場合はwingetでインストールできます。 winget install meld Macの場合はbrewでインストール可能です。 brew install meld 使い方 とてもシンプルです。 対象のファイルを選択するか、「Blank Comparison」を選択するとdiffの画面に切り替わります。 それぞれのウィンドウに比較したいテキストを入力することで比較できます。 かなりシンプルなツールですが、必要な機能があるので重宝しそうです。 ということで今回はこれで👍

2026年5月17日 · にあえん