Files
learngo/x-tba/foundations/03-if-switch-loop/01-for-crunch-the-primes/main.go

64 lines
952 B
Go
Raw Normal View History

2019-05-11 13:22:43 +03:00
// For more tutorials: https://blog.learngoprogramming.com
//
// Copyright © 2018 Inanc Gumus
// Learn Go Programming Course
// License: https://creativecommons.org/licenses/by-nc-sa/4.0/
//
// go run . {1..100}
package main
import (
"fmt"
"os"
"strconv"
)
func main() {
2019-05-11 16:37:39 +03:00
const usageMsg = `Type a couple of unique numbers.
Separate them with spaces.`
2019-05-11 13:22:43 +03:00
// remember [1:] skips the first argument
2019-05-11 16:37:39 +03:00
args := os.Args[1:]
if len(args) == 0 {
fmt.Println(usageMsg)
return
}
2019-05-11 13:22:43 +03:00
main:
2019-05-11 16:37:39 +03:00
for _, arg := range args {
2019-05-11 13:22:43 +03:00
n, err := strconv.Atoi(arg)
if err != nil {
// skip non-numerics
continue
}
switch {
// prime
case n == 2 || n == 3:
fmt.Print(n, " ")
continue
// not a prime
case n <= 1 || n%2 == 0 || n%3 == 0:
continue
}
for i, w := 5, 2; i*i <= n; {
// not a prime
if n%i == 0 {
continue main
}
i += w
w = 6 - w
}
// all checks ok: it's a prime
fmt.Print(n, " ")
}
fmt.Println()
}