Exercism: Go version of the 'Leap' exercise.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

67 lines
2.6 KiB

6 years ago
  1. # Leap
  2. Given a year, report if it is a leap year.
  3. The tricky thing here is that a leap year in the Gregorian calendar occurs:
  4. ```text
  5. on every year that is evenly divisible by 4
  6. except every year that is evenly divisible by 100
  7. unless the year is also evenly divisible by 400
  8. ```
  9. For example, 1997 is not a leap year, but 1996 is. 1900 is not a leap
  10. year, but 2000 is.
  11. If your language provides a method in the standard library that does
  12. this look-up, pretend it doesn't exist and implement it yourself.
  13. ## Notes
  14. Though our exercise adopts some very simple rules, there is more to
  15. learn!
  16. For a delightful, four minute explanation of the whole leap year
  17. phenomenon, go watch [this youtube video][video].
  18. [video]: http://www.youtube.com/watch?v=xX96xng7sAE
  19. You will see a `cases_test.go` file in this exercise. This holds the test
  20. cases used in the `leap_test.go`. You can mostly ignore this file.
  21. However, if you are interested... we sometimes generate the test data from a
  22. [cross language repository][problem-specifications-leap]. In that repo
  23. exercises may have a [.json file][problem-specifications-leap-json] that
  24. contains common test data. Some of our local exercises have an
  25. [intermediary program][local-leap-gen] that takes the problem specification
  26. JSON and turns in into Go structs that are fed into the `<exercise>_test.go`
  27. file. The Go specific transformation of that data lives in the `cases_test.go` file.
  28. [problem-specifications-leap]: https://github.com/exercism/problem-specifications/tree/master/exercises/leap
  29. [problem-specifications-leap-json]: https://github.com/exercism/problem-specifications/blob/master/exercises/leap/canonical-data.json
  30. [local-leap-gen]: https://github.com/exercism/go/blob/master/exercises/leap/.meta/gen.go
  31. ## Running the tests
  32. To run the tests run the command `go test` from within the exercise directory.
  33. If the test suite contains benchmarks, you can run these with the `--bench` and `--benchmem`
  34. flags:
  35. go test -v --bench . --benchmem
  36. Keep in mind that each reviewer will run benchmarks on a different machine, with
  37. different specs, so the results from these benchmark tests may vary.
  38. ## Further information
  39. For more detailed information about the Go track, including how to get help if
  40. you're having trouble, please visit the exercism.io [Go language page](http://exercism.io/languages/go/resources).
  41. ## Source
  42. JavaRanch Cattle Drive, exercise 3 [http://www.javaranch.com/leap.jsp](http://www.javaranch.com/leap.jsp)
  43. ## Submitting Incomplete Solutions
  44. It's possible to submit an incomplete solution so you can see how others have completed the exercise.