Оригинальные примеры в golang playground

Пользователь

от jaclyn , в категории: Общие вопросы , 5 лет назад

Очень интересует, увидеть много разных примеров на Golang. Хотелось бы увидеть связанные, с графикой. В идеале с анимацией.

Facebook Vk Ok Twitter LinkedIn Telegram Whatsapp Pocket

4 ответа

Пользователь

от oleta , 5 лет назад

Это конечно не графический пример, но оригинальный. Создание функции в Golang.

package main

 

import "fmt"

 

// kelvinToCelsius конвертирует °K в °C

func kelvinToCelsius(k float64) float64 { // Объявляет функцию, что принимает параметр и возвращает результат

   k -= 273.15

   return k

}

 

func main() {

   kelvin := 294.0

   celsius := kelvinToCelsius(kelvin) // Вызывает функцию передачи kelvin как первого аргумента

   fmt.Print(kelvin, "° K is ", celsius, "° C") // Выводит: 294° K is 20.850000000000023° C

 }

Пользователь

от alexandra_jones , 5 лет назад

Пример, над которым можно издеваться. Редактируйте в https://play.golang.org

package main

 

import "fmt"

 

func kelvinToCelsius(k float64) float64 {

   return k - 273.15

}

 

func celsiusToFahrenheit(c float64) float64 {

   return (c * 9.0 / 5.0) + 32.0

}

 

func kelvinToFahrenheit(k float64) float64 {

   return celsiusToFahrenheit(kelvinToCelsius(k))

}

 

func main() {

   fmt.Printf("233° K is %.2f° C\n", kelvinToCelsius(233))

   fmt.Printf("0° K is %.2f° F\n", kelvinToFahrenheit(0))

}

Пользователь

от jairo_breitenberg , 5 лет назад

Привожу оригинальный пример игры Судаку.

package main

 

import (

    "errors"

    "fmt"

    "os"

)

 

const (

    rows, columns = 9, 9

    empty         = 0

)

 

// Cell является квадратом сетки Судоку

type Cell struct {

    digit int8

    fixed bool

}

 

// Grid является сеткой Судоку

type Grid [rows][columns]Cell

 

// Ошибки, что могут возникнуть

var (

    ErrBounds     = errors.New("за пределами")

    ErrDigit      = errors.New("неправильная цифра")

    ErrInRow      = errors.New("эта цифра уже есть в ряду")

    ErrInColumn   = errors.New("эта цифра уже есть в столбце")

    ErrInRegion   = errors.New("в данной части эта цифра уже есть")

    ErrFixedDigit = errors.New("начальные цифры нельзя переписать")

)

 

// NewSudoku делает новую сетку Судоку

func NewSudoku(digits [rows][columns]int8) *Grid {

    var grid Grid

    for r := 0; r < rows; r++ {

        for c := 0; c < columns; c++ {

            d := digits[r][c]

            if d != empty {

                grid[r][c].digit = d

                grid[r][c].fixed = true

            }

        }

    }

    return &grid

}

 

// Устанавливает цифры на сетку

func (g *Grid) Set(row, column int, digit int8) error {

    switch {

    case !inBounds(row, column):

        return ErrBounds

    case !validDigit(digit):

        return ErrDigit

    case g.isFixed(row, column):

        return ErrFixedDigit

    case g.inRow(row, digit):

        return ErrInRow

    case g.inColumn(column, digit):

        return ErrInColumn

    case g.inRegion(row, column, digit):

        return ErrInRegion

    }

 

    g[row][column].digit = digit

    return nil

}

 

// Очищает клетку на сетке Судоку

func (g *Grid) Clear(row, column int) error {

    switch {

    case !inBounds(row, column):

        return ErrBounds

    case g.isFixed(row, column):

        return ErrFixedDigit

    }

 

    g[row][column].digit = empty

    return nil

 

}

 

func inBounds(row, column int) bool {

    if row < 0 || row >= rows || column < 0 || column >= columns {

        return false

    }

    return true

}

 

func validDigit(digit int8) bool {

    return digit >= 1 && digit <= 9

}

 

func (g *Grid) inRow(row int, digit int8) bool {

    for c := 0; c < columns; c++ {

        if g[row][c].digit == digit {

            return true

        }

    }

    return false

}

 

func (g *Grid) inColumn(column int, digit int8) bool {

    for r := 0; r < rows; r++ {

        if g[r][column].digit == digit {

            return true

        }

    }

    return false

}

 

func (g *Grid) inRegion(row, column int, digit int8) bool {

    startRow, startColumn := row/3*3, column/3*3

    for r := startRow; r < startRow+3; r++ {

        for c := startColumn; c < startColumn+3; c++ {

            if g[r][c].digit == digit {

                return true

            }

        }

    }

    return false

}

 

func (g *Grid) isFixed(row, column int) bool {

    return g[row][column].fixed

}

 

func main() {

    s := NewSudoku([rows][columns]int8{

        {5, 3, 0, 0, 7, 0, 0, 0, 0},

        {6, 0, 0, 1, 9, 5, 0, 0, 0},

        {0, 9, 8, 0, 0, 0, 0, 6, 0},

        {8, 0, 0, 0, 6, 0, 0, 0, 3},

        {4, 0, 0, 8, 0, 3, 0, 0, 1},

        {7, 0, 0, 0, 2, 0, 0, 0, 6},

        {0, 6, 0, 0, 0, 0, 2, 8, 0},

        {0, 0, 0, 4, 1, 9, 0, 0, 5},

        {0, 0, 0, 0, 8, 0, 0, 7, 9},

    })

 

    err := s.Set(1, 1, 4)

    if err != nil {

        fmt.Println(err)

        os.Exit(1)

    }

 

    for _, row := range s {

        fmt.Println(row)

    }

}


Пользователь

от rupert , 5 лет назад

Программа-задача. Она посчитает, насколько быстро должна лететь ракета (км/ч), чтобы добраться до Марса за 28 дней. Предполагаемое расстояние от Земли до Марса равно 56 000 000 км.

package main

 

import "fmt"

 

func main() {

   const hoursPerDay = 24

 

   var days = 28

   var distance = 56000000 // km

 

   fmt.Println(distance/(days*hoursPerDay), "км/ч")

}