trackler 2.2.1.56 → 2.2.1.57
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/lib/trackler/version.rb +1 -1
- data/problem-specifications/TOPICS.txt +2 -2
- data/problem-specifications/exercises/zipper/description.md +1 -1
- data/tracks/dart/test/exercises_test.dart +9 -9
- data/tracks/delphi/exercises/circular-buffer/uCircularBufferExample.pas +3 -3
- data/tracks/delphi/exercises/circular-buffer/uCircularBufferTests.pas +160 -86
- data/tracks/delphi/exercises/phone-number/README.md +1 -1
- data/tracks/erlang/config.json +10 -0
- data/tracks/erlang/exercises/isogram/README.md +65 -0
- data/tracks/erlang/exercises/isogram/include/exercism.hrl +11 -0
- data/tracks/erlang/exercises/isogram/rebar.config +30 -0
- data/tracks/erlang/exercises/isogram/src/example.erl +16 -0
- data/tracks/erlang/exercises/isogram/src/isogram.app.src +9 -0
- data/tracks/erlang/exercises/isogram/src/isogram.erl +9 -0
- data/tracks/erlang/exercises/isogram/test/isogram_tests.erl +32 -0
- data/tracks/fsharp/exercises/binary-search/BinarySearch.fs +1 -1
- data/tracks/fsharp/exercises/binary-search/BinarySearchTest.fs +58 -30
- data/tracks/fsharp/exercises/binary-search/Example.fs +1 -1
- data/tracks/fsharp/exercises/poker/Example.fs +23 -20
- data/tracks/fsharp/exercises/poker/PokerTest.fs +135 -76
- data/tracks/fsharp/generators/Generators.fs +21 -0
- data/tracks/go/README.md +0 -15
- data/tracks/go/bin/run-generators +11 -0
- data/tracks/go/config.json +389 -277
- data/tracks/go/config/maintainers.json +2 -2
- data/tracks/go/docs/TESTS.md +0 -15
- data/tracks/go/exercises/accumulate/accumulate_test.go +0 -8
- data/tracks/go/exercises/accumulate/example.go +0 -2
- data/tracks/go/exercises/acronym/acronym.go +14 -2
- data/tracks/go/exercises/acronym/acronym_test.go +0 -8
- data/tracks/go/exercises/acronym/cases_test.go +2 -2
- data/tracks/go/exercises/acronym/example.go +0 -2
- data/tracks/go/exercises/all-your-base/all_your_base_test.go +0 -8
- data/tracks/go/exercises/all-your-base/example.go +0 -2
- data/tracks/go/exercises/allergies/allergies_test.go +0 -8
- data/tracks/go/exercises/allergies/example.go +0 -2
- data/tracks/go/exercises/anagram/.meta/gen.go +55 -0
- data/tracks/go/exercises/anagram/anagram_test.go +0 -130
- data/tracks/go/exercises/anagram/cases_test.go +164 -0
- data/tracks/go/exercises/anagram/example.go +0 -2
- data/tracks/go/exercises/atbash-cipher/atbash_cipher_test.go +0 -8
- data/tracks/go/exercises/atbash-cipher/cases_test.go +2 -2
- data/tracks/go/exercises/atbash-cipher/example.go +0 -2
- data/tracks/go/exercises/bank-account/bank_account_test.go +0 -8
- data/tracks/go/exercises/bank-account/example.go +0 -2
- data/tracks/go/exercises/beer-song/beer_test.go +0 -8
- data/tracks/go/exercises/beer-song/example.go +0 -2
- data/tracks/go/exercises/binary-search-tree/binary_search_tree_test.go +0 -8
- data/tracks/go/exercises/binary-search-tree/example.go +0 -2
- data/tracks/go/exercises/binary-search/binary_search_test.go +0 -8
- data/tracks/go/exercises/binary-search/example.go +0 -2
- data/tracks/go/exercises/binary/binary_test.go +0 -11
- data/tracks/go/exercises/binary/example.go +0 -2
- data/tracks/go/exercises/bob/bob.go +14 -0
- data/tracks/go/exercises/bob/bob_test.go +2 -10
- data/tracks/go/exercises/bob/cases_test.go +2 -2
- data/tracks/go/exercises/bob/example.go +12 -13
- data/tracks/go/exercises/book-store/README.md +92 -0
- data/tracks/go/exercises/book-store/book_store_test.go +91 -0
- data/tracks/go/exercises/book-store/example.go +52 -0
- data/tracks/go/exercises/bowling/bowling_test.go +0 -8
- data/tracks/go/exercises/bowling/cases_test.go +2 -2
- data/tracks/go/exercises/bowling/example.go +0 -2
- data/tracks/go/exercises/bracket-push/bracket_push_test.go +0 -8
- data/tracks/go/exercises/bracket-push/cases_test.go +2 -2
- data/tracks/go/exercises/bracket-push/example.go +0 -3
- data/tracks/go/exercises/change/cases_test.go +10 -3
- data/tracks/go/exercises/change/change_test.go +1 -9
- data/tracks/go/exercises/change/example.go +0 -2
- data/tracks/go/exercises/circular-buffer/circular_buffer_test.go +0 -8
- data/tracks/go/exercises/circular-buffer/example.go +0 -2
- data/tracks/go/exercises/clock/cases_test.go +2 -2
- data/tracks/go/exercises/clock/clock_test.go +2 -9
- data/tracks/go/exercises/clock/example.go +0 -2
- data/tracks/go/exercises/collatz-conjecture/README.md +51 -0
- data/tracks/go/exercises/collatz-conjecture/collatz_conjecture_test.go +77 -0
- data/tracks/go/exercises/collatz-conjecture/example.go +24 -0
- data/tracks/go/exercises/connect/cases_test.go +2 -2
- data/tracks/go/exercises/connect/connect_test.go +0 -8
- data/tracks/go/exercises/connect/example.go +0 -2
- data/tracks/go/exercises/crypto-square/crypto_square_test.go +0 -8
- data/tracks/go/exercises/crypto-square/example.go +0 -2
- data/tracks/go/exercises/custom-set/cases_test.go +2 -2
- data/tracks/go/exercises/custom-set/custom_set_test.go +0 -8
- data/tracks/go/exercises/custom-set/example.go +0 -2
- data/tracks/go/exercises/custom-set/example_slice.go +0 -2
- data/tracks/go/exercises/diamond/diamond_test.go +0 -8
- data/tracks/go/exercises/diamond/example.go +0 -2
- data/tracks/go/exercises/difference-of-squares/difference_of_squares_test.go +0 -8
- data/tracks/go/exercises/difference-of-squares/example.go +0 -2
- data/tracks/go/exercises/diffie-hellman/diffie_hellman_test.go +0 -8
- data/tracks/go/exercises/diffie-hellman/example.go +0 -2
- data/tracks/go/exercises/error-handling/error_handling_test.go +0 -7
- data/tracks/go/exercises/error-handling/example.go +0 -2
- data/tracks/go/exercises/etl/etl_test.go +0 -8
- data/tracks/go/exercises/etl/example.go +0 -2
- data/tracks/go/exercises/flatten-array/.meta/gen.go +52 -0
- data/tracks/go/exercises/flatten-array/README.md +35 -0
- data/tracks/go/exercises/flatten-array/cases_test.go +42 -0
- data/tracks/go/exercises/flatten-array/example.go +25 -0
- data/tracks/go/exercises/flatten-array/flatten_test.go +23 -0
- data/tracks/go/exercises/food-chain/example.go +0 -2
- data/tracks/go/exercises/food-chain/food_chain_test.go +0 -8
- data/tracks/go/exercises/forth/cases_test.go +2 -2
- data/tracks/go/exercises/forth/example.go +0 -2
- data/tracks/go/exercises/forth/forth_test.go +0 -8
- data/tracks/go/exercises/gigasecond/cases_test.go +2 -2
- data/tracks/go/exercises/gigasecond/example.go +0 -2
- data/tracks/go/exercises/gigasecond/gigasecond.go +13 -3
- data/tracks/go/exercises/gigasecond/gigasecond_test.go +0 -8
- data/tracks/go/exercises/grade-school/example.go +0 -2
- data/tracks/go/exercises/grade-school/grade_school_test.go +0 -8
- data/tracks/go/exercises/grains/example.go +0 -2
- data/tracks/go/exercises/grains/grains_test.go +0 -8
- data/tracks/go/exercises/hamming/.meta/hints.md +4 -0
- data/tracks/go/exercises/hamming/README.md +6 -0
- data/tracks/go/exercises/hamming/example.go +0 -2
- data/tracks/go/exercises/hamming/hamming.go +0 -2
- data/tracks/go/exercises/hamming/hamming_test.go +0 -8
- data/tracks/go/exercises/hello-world/hello_world.go +9 -1
- data/tracks/go/exercises/hexadecimal/example.go +0 -2
- data/tracks/go/exercises/hexadecimal/hexadecimal_test.go +0 -8
- data/tracks/go/exercises/house/example.go +0 -2
- data/tracks/go/exercises/house/house_test.go +0 -8
- data/tracks/go/exercises/isbn-verifier/README.md +60 -0
- data/tracks/go/exercises/isbn-verifier/example.go +57 -0
- data/tracks/go/exercises/isbn-verifier/isbn_verifier_test.go +35 -0
- data/tracks/go/exercises/isogram/example.go +0 -2
- data/tracks/go/exercises/isogram/isogram_test.go +0 -8
- data/tracks/go/exercises/kindergarten-garden/example.go +0 -2
- data/tracks/go/exercises/kindergarten-garden/kindergarten_garden_test.go +0 -8
- data/tracks/go/exercises/largest-series-product/cases_test.go +2 -2
- data/tracks/go/exercises/largest-series-product/example.go +0 -2
- data/tracks/go/exercises/largest-series-product/largest_series_product_test.go +0 -8
- data/tracks/go/exercises/leap/.meta/hints.md +14 -0
- data/tracks/go/exercises/leap/README.md +16 -0
- data/tracks/go/exercises/leap/cases_test.go +4 -4
- data/tracks/go/exercises/leap/example.go +0 -2
- data/tracks/go/exercises/leap/leap.go +11 -2
- data/tracks/go/exercises/leap/leap_test.go +0 -15
- data/tracks/go/exercises/ledger/example.go +0 -2
- data/tracks/go/exercises/ledger/ledger.go +0 -2
- data/tracks/go/exercises/ledger/ledger_test.go +0 -8
- data/tracks/go/exercises/luhn/cases_test.go +2 -2
- data/tracks/go/exercises/luhn/example.go +0 -2
- data/tracks/go/exercises/luhn/luhn_test.go +0 -8
- data/tracks/go/exercises/matrix/example.go +0 -2
- data/tracks/go/exercises/matrix/matrix_test.go +0 -8
- data/tracks/go/exercises/meetup/cases_test.go +2 -2
- data/tracks/go/exercises/meetup/example.go +0 -2
- data/tracks/go/exercises/meetup/meetup_test.go +0 -8
- data/tracks/go/exercises/minesweeper/example.go +0 -2
- data/tracks/go/exercises/minesweeper/minesweeper_test.go +0 -8
- data/tracks/go/exercises/nth-prime/example.go +0 -2
- data/tracks/go/exercises/nth-prime/nth_prime_test.go +0 -8
- data/tracks/go/exercises/nucleotide-count/example.go +0 -2
- data/tracks/go/exercises/nucleotide-count/nucleotide_count.go +26 -0
- data/tracks/go/exercises/nucleotide-count/nucleotide_count_test.go +0 -8
- data/tracks/go/exercises/ocr-numbers/example.go +0 -2
- data/tracks/go/exercises/ocr-numbers/ocr_numbers_test.go +0 -8
- data/tracks/go/exercises/octal/example.go +0 -2
- data/tracks/go/exercises/octal/octal_test.go +0 -8
- data/tracks/go/exercises/paasio/example.go +0 -2
- data/tracks/go/exercises/paasio/paasio_test.go +0 -8
- data/tracks/go/exercises/palindrome-products/example.go +0 -2
- data/tracks/go/exercises/palindrome-products/palindrome_products_test.go +0 -8
- data/tracks/go/exercises/pangram/example.go +0 -2
- data/tracks/go/exercises/pangram/pangram_test.go +2 -8
- data/tracks/go/exercises/parallel-letter-frequency/example.go +0 -2
- data/tracks/go/exercises/parallel-letter-frequency/parallel_letter_frequency_test.go +0 -8
- data/tracks/go/exercises/pascals-triangle/example.go +0 -2
- data/tracks/go/exercises/pascals-triangle/pascals_triangle_test.go +0 -8
- data/tracks/go/exercises/perfect-numbers/example.go +0 -2
- data/tracks/go/exercises/perfect-numbers/perfect_numbers_test.go +0 -8
- data/tracks/go/exercises/phone-number/cases_test.go +2 -2
- data/tracks/go/exercises/phone-number/example.go +0 -2
- data/tracks/go/exercises/phone-number/phone_number_test.go +0 -8
- data/tracks/go/exercises/pig-latin/example.go +0 -2
- data/tracks/go/exercises/pig-latin/pig_latin_test.go +0 -8
- data/tracks/go/exercises/poker/.meta/hints.md +7 -0
- data/tracks/go/exercises/poker/README.md +9 -0
- data/tracks/go/exercises/poker/cases_test.go +2 -2
- data/tracks/go/exercises/poker/example.go +0 -2
- data/tracks/go/exercises/poker/poker_test.go +0 -11
- data/tracks/go/exercises/pov/example.go +0 -2
- data/tracks/go/exercises/pov/pov_test.go +1 -9
- data/tracks/go/exercises/prime-factors/example.go +0 -2
- data/tracks/go/exercises/prime-factors/prime_factors_test.go +1 -9
- data/tracks/go/exercises/protein-translation/example.go +0 -2
- data/tracks/go/exercises/protein-translation/protein_translation_test.go +0 -8
- data/tracks/go/exercises/pythagorean-triplet/example.go +0 -2
- data/tracks/go/exercises/pythagorean-triplet/pythagorean_triplet_test.go +0 -8
- data/tracks/go/exercises/queen-attack/example.go +0 -2
- data/tracks/go/exercises/queen-attack/queen_attack_test.go +0 -8
- data/tracks/go/exercises/raindrops/.meta/hints.md +7 -0
- data/tracks/go/exercises/raindrops/cases_test.go +2 -2
- data/tracks/go/exercises/raindrops/example.go +0 -2
- data/tracks/go/exercises/raindrops/raindrops_test.go +0 -8
- data/tracks/go/exercises/react/example.go +0 -2
- data/tracks/go/exercises/react/react_test.go +0 -11
- data/tracks/go/exercises/rna-transcription/cases_test.go +2 -2
- data/tracks/go/exercises/rna-transcription/example.go +0 -2
- data/tracks/go/exercises/rna-transcription/rna_transcription.go +6 -0
- data/tracks/go/exercises/rna-transcription/rna_transcription_test.go +0 -8
- data/tracks/go/exercises/robot-name/example.go +0 -2
- data/tracks/go/exercises/robot-name/robot_name_test.go +0 -8
- data/tracks/go/exercises/robot-simulator/example.go +0 -1
- data/tracks/go/exercises/robot-simulator/robot_simulator_test.go +0 -8
- data/tracks/go/exercises/roman-numerals/cases_test.go +2 -2
- data/tracks/go/exercises/roman-numerals/example.go +0 -2
- data/tracks/go/exercises/roman-numerals/roman_numerals_test.go +0 -8
- data/tracks/go/exercises/rotational-cipher/README.md +56 -0
- data/tracks/go/exercises/rotational-cipher/example.go +20 -0
- data/tracks/go/exercises/rotational-cipher/rotational_cipher_test.go +86 -0
- data/tracks/go/exercises/run-length-encoding/README.md +31 -0
- data/tracks/go/exercises/run-length-encoding/example.go +53 -0
- data/tracks/go/exercises/run-length-encoding/run_length_encoding_test.go +59 -0
- data/tracks/go/exercises/saddle-points/example.go +0 -2
- data/tracks/go/exercises/saddle-points/saddle_points_test.go +0 -8
- data/tracks/go/exercises/say/.meta/gen.go +70 -0
- data/tracks/go/exercises/say/cases_test.go +88 -0
- data/tracks/go/exercises/say/example.go +12 -6
- data/tracks/go/exercises/say/say_test.go +17 -43
- data/tracks/go/exercises/scrabble-score/cases_test.go +2 -2
- data/tracks/go/exercises/scrabble-score/example.go +0 -3
- data/tracks/go/exercises/scrabble-score/scrabble_score_test.go +0 -8
- data/tracks/go/exercises/secret-handshake/cases_test.go +2 -2
- data/tracks/go/exercises/secret-handshake/example.go +0 -2
- data/tracks/go/exercises/secret-handshake/secret_handshake_test.go +0 -8
- data/tracks/go/exercises/series/example.go +0 -2
- data/tracks/go/exercises/series/series_test.go +0 -8
- data/tracks/go/exercises/sieve/example.go +0 -2
- data/tracks/go/exercises/sieve/sieve_test.go +0 -8
- data/tracks/go/exercises/simple-cipher/example.go +0 -2
- data/tracks/go/exercises/simple-cipher/simple_cipher_test.go +0 -8
- data/tracks/go/exercises/space-age/.meta/gen.go +56 -0
- data/tracks/go/exercises/space-age/README.md +42 -0
- data/tracks/go/exercises/space-age/cases_test.go +61 -0
- data/tracks/go/exercises/space-age/example.go +36 -0
- data/tracks/go/exercises/space-age/space_age_test.go +22 -0
- data/tracks/go/exercises/spiral-matrix/README.md +48 -0
- data/tracks/go/exercises/spiral-matrix/example.go +93 -0
- data/tracks/go/exercises/spiral-matrix/spiral_matrix_test.go +71 -0
- data/tracks/go/exercises/strain/example.go +0 -2
- data/tracks/go/exercises/strain/strain_test.go +0 -8
- data/tracks/go/exercises/sublist/.meta/gen.go +56 -0
- data/tracks/go/exercises/sublist/README.md +39 -0
- data/tracks/go/exercises/sublist/cases_test.go +115 -0
- data/tracks/go/exercises/sublist/example.go +49 -0
- data/tracks/go/exercises/sublist/sublist_test.go +22 -0
- data/tracks/go/exercises/sum-of-multiples/cases_test.go +4 -3
- data/tracks/go/exercises/sum-of-multiples/example.go +0 -2
- data/tracks/go/exercises/sum-of-multiples/sum_of_multiples_test.go +0 -8
- data/tracks/go/exercises/tournament/example.go +0 -2
- data/tracks/go/exercises/tournament/tournament_test.go +0 -11
- data/tracks/go/exercises/transpose/cases_test.go +2 -2
- data/tracks/go/exercises/transpose/example.go +0 -2
- data/tracks/go/exercises/transpose/transpose_test.go +0 -8
- data/tracks/go/exercises/tree-building/example.go +0 -2
- data/tracks/go/exercises/tree-building/tree_building.go +0 -2
- data/tracks/go/exercises/tree-building/tree_test.go +0 -11
- data/tracks/go/exercises/triangle/.meta/hints.md +10 -0
- data/tracks/go/exercises/triangle/example.go +0 -2
- data/tracks/go/exercises/triangle/triangle.go +21 -9
- data/tracks/go/exercises/triangle/triangle_test.go +0 -8
- data/tracks/go/exercises/trinary/example.go +0 -2
- data/tracks/go/exercises/trinary/trinary_test.go +0 -8
- data/tracks/go/exercises/twelve-days/example.go +0 -2
- data/tracks/go/exercises/twelve-days/twelve_days_test.go +0 -8
- data/tracks/go/exercises/two-fer/two_fer.go +2 -2
- data/tracks/go/exercises/variable-length-quantity/cases_test.go +2 -2
- data/tracks/go/exercises/variable-length-quantity/example.go +0 -2
- data/tracks/go/exercises/variable-length-quantity/variable_length_quantity_test.go +0 -8
- data/tracks/go/exercises/word-count/cases_test.go +2 -2
- data/tracks/go/exercises/word-count/example.go +0 -2
- data/tracks/go/exercises/word-count/word_count_test.go +4 -7
- data/tracks/go/exercises/word-search/.meta/gen.go +96 -0
- data/tracks/go/exercises/word-search/cases_test.go +154 -0
- data/tracks/go/exercises/word-search/example.go +0 -2
- data/tracks/go/exercises/word-search/word_search_test.go +16 -52
- data/tracks/go/exercises/wordy/example.go +0 -2
- data/tracks/go/exercises/wordy/wordy_test.go +0 -8
- data/tracks/go/gen/gen.go +4 -1
- data/tracks/java/exercises/phone-number/README.md +1 -1
- data/tracks/kotlin/exercises/phone-number/README.md +1 -1
- data/tracks/perl6/config.json +50 -0
- data/tracks/perl6/exercises/etl/ETL.pm6 +6 -0
- data/tracks/perl6/exercises/etl/Example.pm6 +7 -0
- data/tracks/perl6/exercises/etl/README.md +72 -0
- data/tracks/perl6/exercises/etl/etl.t +139 -0
- data/tracks/perl6/exercises/etl/example.yaml +35 -0
- data/tracks/perl6/exercises/hamming/Example.pm6 +6 -0
- data/tracks/perl6/exercises/hamming/Hamming.pm6 +4 -0
- data/tracks/perl6/exercises/hamming/README.md +61 -0
- data/tracks/perl6/exercises/hamming/example.yaml +22 -0
- data/tracks/perl6/exercises/hamming/hamming.t +175 -0
- data/tracks/perl6/exercises/meetup/Example.pm6 +37 -0
- data/tracks/perl6/exercises/meetup/Meetup.pm6 +4 -0
- data/tracks/perl6/exercises/meetup/README.md +48 -0
- data/tracks/perl6/exercises/meetup/example.yaml +48 -0
- data/tracks/perl6/exercises/meetup/meetup.t +907 -0
- data/tracks/perl6/exercises/pangram/Example.pm6 +5 -0
- data/tracks/perl6/exercises/pangram/Pangram.pm6 +4 -0
- data/tracks/perl6/exercises/pangram/README.md +34 -0
- data/tracks/perl6/exercises/pangram/example.yaml +17 -0
- data/tracks/perl6/exercises/pangram/pangram.t +125 -0
- data/tracks/perl6/exercises/phone-number/README.md +1 -1
- data/tracks/perl6/exercises/two-fer/Example.pm6 +14 -0
- data/tracks/perl6/exercises/two-fer/README.md +38 -0
- data/tracks/perl6/exercises/two-fer/TwoFer.pm6 +15 -0
- data/tracks/perl6/exercises/two-fer/example.yaml +43 -0
- data/tracks/perl6/exercises/two-fer/two-fer.t +82 -0
- data/tracks/php/config.json +13 -0
- data/tracks/php/exercises/rail-fence-cipher/README.md +80 -0
- data/tracks/php/exercises/rail-fence-cipher/example.php +61 -0
- data/tracks/php/exercises/rail-fence-cipher/rail-fence-cipher_test.php +76 -0
- data/tracks/purescript/.travis.yml +1 -1
- data/tracks/python/config.json +13 -0
- data/tracks/python/exercises/alphametics/example.py +42 -29
- data/tracks/python/exercises/crypto-square/crypto_square_test.py +20 -13
- data/tracks/python/exercises/crypto-square/example.py +1 -1
- data/tracks/python/exercises/kindergarten-garden/kindergarten_garden_test.py +15 -2
- data/tracks/python/exercises/phone-number/README.md +2 -1
- data/tracks/python/exercises/pov/README.md +53 -0
- data/tracks/python/exercises/pov/example.py +70 -0
- data/tracks/python/exercises/pov/pov.py +25 -0
- data/tracks/python/exercises/pov/pov_test.py +200 -0
- data/tracks/python/test/check-exercises.py +11 -1
- data/tracks/ruby/exercises/meetup/.meta/.version +1 -0
- data/tracks/ruby/exercises/meetup/.meta/generator/meetup_case.rb +11 -0
- data/tracks/ruby/exercises/meetup/.meta/solutions/meetup.rb +5 -0
- data/tracks/ruby/exercises/meetup/meetup_test.rb +48 -4
- metadata +90 -8
- data/tracks/go/exercises/accumulate/accumulate.go +0 -5
- data/tracks/go/exercises/clock/clock.go +0 -19
- data/tracks/go/exercises/pangram/pangram.go +0 -5
- data/tracks/go/exercises/raindrops/raindrops.go +0 -8
- data/tracks/go/exercises/twelve-days/HINTS.md +0 -2
- data/tracks/go/exercises/word-count/word_count.go +0 -9
@@ -0,0 +1,36 @@
|
|
1
|
+
package space
|
2
|
+
|
3
|
+
// Planet is the location where age will be calculated
|
4
|
+
type Planet string
|
5
|
+
|
6
|
+
// Possible planets
|
7
|
+
const (
|
8
|
+
PlanetMercury Planet = "Mercury"
|
9
|
+
PlanetVenus Planet = "Venus"
|
10
|
+
PlanetEarth Planet = "Earth"
|
11
|
+
PlanetMars Planet = "Mars"
|
12
|
+
PlanetJupiter Planet = "Jupiter"
|
13
|
+
PlanetSaturn Planet = "Saturn"
|
14
|
+
PlanetUranus Planet = "Uranus"
|
15
|
+
PlanetNeptune Planet = "Neptune"
|
16
|
+
)
|
17
|
+
|
18
|
+
var periods = map[Planet]float64{
|
19
|
+
PlanetMercury: 76005.3024,
|
20
|
+
PlanetVenus: 194139.072,
|
21
|
+
PlanetEarth: 315581.4976,
|
22
|
+
PlanetMars: 593542.944,
|
23
|
+
PlanetJupiter: 3743357.76,
|
24
|
+
PlanetSaturn: 9295966.08,
|
25
|
+
PlanetUranus: 26610418.08,
|
26
|
+
PlanetNeptune: 52004185.92,
|
27
|
+
}
|
28
|
+
|
29
|
+
// Age calculates number of years in the given planet
|
30
|
+
func Age(seconds float64, planet Planet) float64 {
|
31
|
+
period, ok := periods[planet]
|
32
|
+
if !ok {
|
33
|
+
period = 1
|
34
|
+
}
|
35
|
+
return float64(int64(seconds/period+0.5)) / 100
|
36
|
+
}
|
@@ -0,0 +1,22 @@
|
|
1
|
+
package space
|
2
|
+
|
3
|
+
import (
|
4
|
+
"testing"
|
5
|
+
)
|
6
|
+
|
7
|
+
func TestAge(t *testing.T) {
|
8
|
+
for _, tc := range testCases {
|
9
|
+
if actual := Age(tc.seconds, tc.planet); actual != tc.expected {
|
10
|
+
t.Fatalf("FAIL: %s\nExpected: %#v\nActual: %#v", tc.description, tc.expected, actual)
|
11
|
+
}
|
12
|
+
t.Logf("PASS: %s", tc.description)
|
13
|
+
}
|
14
|
+
}
|
15
|
+
|
16
|
+
func BenchmarkAge(b *testing.B) {
|
17
|
+
for i := 0; i < b.N; i++ {
|
18
|
+
for _, tc := range testCases {
|
19
|
+
Age(tc.seconds, tc.planet)
|
20
|
+
}
|
21
|
+
}
|
22
|
+
}
|
@@ -0,0 +1,48 @@
|
|
1
|
+
# Spiral Matrix
|
2
|
+
|
3
|
+
Given the size, return a square matrix of numbers in spiral order.
|
4
|
+
|
5
|
+
The matrix should be filled with natural numbers, starting from 1
|
6
|
+
in the top-left corner, increasing in an inward, clockwise spiral order,
|
7
|
+
like these examples:
|
8
|
+
|
9
|
+
###### Spiral matrix of size 3
|
10
|
+
|
11
|
+
```text
|
12
|
+
1 2 3
|
13
|
+
8 9 4
|
14
|
+
7 6 5
|
15
|
+
```
|
16
|
+
|
17
|
+
###### Spiral matrix of size 4
|
18
|
+
|
19
|
+
```text
|
20
|
+
1 2 3 4
|
21
|
+
12 13 14 5
|
22
|
+
11 16 15 6
|
23
|
+
10 9 8 7
|
24
|
+
```
|
25
|
+
|
26
|
+
## Running the tests
|
27
|
+
|
28
|
+
To run the tests run the command `go test` from within the exercise directory.
|
29
|
+
|
30
|
+
If the test suite contains benchmarks, you can run these with the `-bench`
|
31
|
+
flag:
|
32
|
+
|
33
|
+
go test -bench .
|
34
|
+
|
35
|
+
Keep in mind that each reviewer will run benchmarks on a different machine, with
|
36
|
+
different specs, so the results from these benchmark tests may vary.
|
37
|
+
|
38
|
+
## Further information
|
39
|
+
|
40
|
+
For more detailed information about the Go track, including how to get help if
|
41
|
+
you're having trouble, please visit the exercism.io [Go language page](http://exercism.io/languages/go/about).
|
42
|
+
|
43
|
+
## Source
|
44
|
+
|
45
|
+
[Reddit r/dailyprogrammer challenge #320 [Easy] Spiral Ascension](https://www.reddit.com/r/dailyprogrammer/comments/6i60lr/20170619_challenge_320_easy_spiral_ascension/)
|
46
|
+
|
47
|
+
## Submitting Incomplete Solutions
|
48
|
+
It's possible to submit an incomplete solution so you can see how others have completed the exercise.
|
@@ -0,0 +1,93 @@
|
|
1
|
+
package spiralmatrix
|
2
|
+
|
3
|
+
import (
|
4
|
+
"fmt"
|
5
|
+
)
|
6
|
+
|
7
|
+
type coordinate struct {
|
8
|
+
x int
|
9
|
+
y int
|
10
|
+
}
|
11
|
+
|
12
|
+
func (co coordinate) withinGrid(size int) bool {
|
13
|
+
return co.x >= 0 && co.x < size && co.y >= 0 && co.y < size
|
14
|
+
}
|
15
|
+
|
16
|
+
type direction int
|
17
|
+
|
18
|
+
const (
|
19
|
+
up direction = iota
|
20
|
+
right
|
21
|
+
down
|
22
|
+
left
|
23
|
+
)
|
24
|
+
|
25
|
+
func (d direction) move(co coordinate) coordinate {
|
26
|
+
switch d {
|
27
|
+
case up:
|
28
|
+
return coordinate{
|
29
|
+
x: co.x - 1,
|
30
|
+
y: co.y,
|
31
|
+
}
|
32
|
+
case right:
|
33
|
+
return coordinate{
|
34
|
+
x: co.x,
|
35
|
+
y: co.y + 1,
|
36
|
+
}
|
37
|
+
case down:
|
38
|
+
return coordinate{
|
39
|
+
x: co.x + 1,
|
40
|
+
y: co.y,
|
41
|
+
}
|
42
|
+
case left:
|
43
|
+
return coordinate{
|
44
|
+
x: co.x,
|
45
|
+
y: co.y - 1,
|
46
|
+
}
|
47
|
+
default:
|
48
|
+
panic(fmt.Sprintf("unexpected direction to move: %v", d))
|
49
|
+
}
|
50
|
+
}
|
51
|
+
|
52
|
+
func (d direction) turnRight() direction {
|
53
|
+
switch d {
|
54
|
+
case up:
|
55
|
+
return right
|
56
|
+
case right:
|
57
|
+
return down
|
58
|
+
case down:
|
59
|
+
return left
|
60
|
+
case left:
|
61
|
+
return up
|
62
|
+
default:
|
63
|
+
panic(fmt.Sprintf("unexpected direction to turn right: %v", d))
|
64
|
+
}
|
65
|
+
}
|
66
|
+
|
67
|
+
// SpiralMatrix is an implementation of the spiral matrix exercise.
|
68
|
+
func SpiralMatrix(size int) [][]int {
|
69
|
+
matrix := make([][]int, size)
|
70
|
+
for i := range matrix {
|
71
|
+
matrix[i] = make([]int, size)
|
72
|
+
}
|
73
|
+
|
74
|
+
co := coordinate{
|
75
|
+
x: 0,
|
76
|
+
y: 0,
|
77
|
+
}
|
78
|
+
dir := right
|
79
|
+
count := size * size
|
80
|
+
for i := 0; i < count; i++ {
|
81
|
+
matrix[co.x][co.y] = i + 1
|
82
|
+
|
83
|
+
maybeNext := dir.move(co)
|
84
|
+
if maybeNext.withinGrid(size) && matrix[maybeNext.x][maybeNext.y] == 0 {
|
85
|
+
co = maybeNext
|
86
|
+
} else {
|
87
|
+
dir = dir.turnRight()
|
88
|
+
co = dir.move(co)
|
89
|
+
}
|
90
|
+
}
|
91
|
+
|
92
|
+
return matrix
|
93
|
+
}
|
@@ -0,0 +1,71 @@
|
|
1
|
+
package spiralmatrix
|
2
|
+
|
3
|
+
import (
|
4
|
+
"reflect"
|
5
|
+
"testing"
|
6
|
+
)
|
7
|
+
|
8
|
+
var testCases = []struct {
|
9
|
+
description string
|
10
|
+
input int
|
11
|
+
expected [][]int
|
12
|
+
}{
|
13
|
+
{
|
14
|
+
description: "empty spiral",
|
15
|
+
input: 0,
|
16
|
+
expected: [][]int{},
|
17
|
+
},
|
18
|
+
{
|
19
|
+
description: "trivial spiral",
|
20
|
+
input: 1,
|
21
|
+
expected: [][]int{
|
22
|
+
{1},
|
23
|
+
},
|
24
|
+
},
|
25
|
+
{
|
26
|
+
description: "spiral of size 2",
|
27
|
+
input: 2,
|
28
|
+
expected: [][]int{
|
29
|
+
{1, 2},
|
30
|
+
{4, 3},
|
31
|
+
},
|
32
|
+
},
|
33
|
+
{
|
34
|
+
description: "spiral of size 3",
|
35
|
+
input: 3,
|
36
|
+
expected: [][]int{
|
37
|
+
{1, 2, 3},
|
38
|
+
{8, 9, 4},
|
39
|
+
{7, 6, 5},
|
40
|
+
},
|
41
|
+
},
|
42
|
+
{
|
43
|
+
description: "spiral of size 4",
|
44
|
+
input: 4,
|
45
|
+
expected: [][]int{
|
46
|
+
{1, 2, 3, 4},
|
47
|
+
{12, 13, 14, 5},
|
48
|
+
{11, 16, 15, 6},
|
49
|
+
{10, 9, 8, 7},
|
50
|
+
},
|
51
|
+
},
|
52
|
+
}
|
53
|
+
|
54
|
+
func TestSpiralMatrix(t *testing.T) {
|
55
|
+
for _, testCase := range testCases {
|
56
|
+
matrix := SpiralMatrix(testCase.input)
|
57
|
+
if !reflect.DeepEqual(matrix, testCase.expected) {
|
58
|
+
t.Fatalf("FAIL: %s\n\tSpiralMatrix(%v)\nexpected: %v\ngot : %v",
|
59
|
+
testCase.description, testCase.input, testCase.expected, matrix)
|
60
|
+
}
|
61
|
+
t.Logf("PASS: %s", testCase.description)
|
62
|
+
}
|
63
|
+
}
|
64
|
+
|
65
|
+
func BenchmarkSpiralMatrix(b *testing.B) {
|
66
|
+
for i := 0; i < b.N; i++ {
|
67
|
+
for _, testCase := range testCases {
|
68
|
+
SpiralMatrix(testCase.input)
|
69
|
+
}
|
70
|
+
}
|
71
|
+
}
|
@@ -19,8 +19,6 @@ import (
|
|
19
19
|
"testing"
|
20
20
|
)
|
21
21
|
|
22
|
-
const targetTestVersion = 1
|
23
|
-
|
24
22
|
func lt10(x int) bool { return x < 10 }
|
25
23
|
func gt10(x int) bool { return x > 10 }
|
26
24
|
func odd(x int) bool { return x&1 == 1 }
|
@@ -64,12 +62,6 @@ var discardTests = []struct {
|
|
64
62
|
Ints{1, 3, 5}},
|
65
63
|
}
|
66
64
|
|
67
|
-
func TestTestVersion(t *testing.T) {
|
68
|
-
if testVersion != targetTestVersion {
|
69
|
-
t.Fatalf("Found testVersion = %v, want %v", testVersion, targetTestVersion)
|
70
|
-
}
|
71
|
-
}
|
72
|
-
|
73
65
|
func TestKeepInts(t *testing.T) {
|
74
66
|
for _, test := range keepTests {
|
75
67
|
// setup here copies test.list, preserving the nil value if it is nil
|
@@ -0,0 +1,56 @@
|
|
1
|
+
package main
|
2
|
+
|
3
|
+
import (
|
4
|
+
"log"
|
5
|
+
"text/template"
|
6
|
+
|
7
|
+
".."
|
8
|
+
"../../../gen"
|
9
|
+
)
|
10
|
+
|
11
|
+
func main() {
|
12
|
+
t, err := template.New("").Parse(tmpl)
|
13
|
+
if err != nil {
|
14
|
+
log.Fatal(err)
|
15
|
+
}
|
16
|
+
var j js
|
17
|
+
if err := gen.Gen("sublist", &j, t); err != nil {
|
18
|
+
log.Fatal(err)
|
19
|
+
}
|
20
|
+
}
|
21
|
+
|
22
|
+
// The JSON structure we expect to be able to unmarshal into
|
23
|
+
type js struct {
|
24
|
+
Exercise string
|
25
|
+
Version string
|
26
|
+
Cases []oneCase
|
27
|
+
}
|
28
|
+
|
29
|
+
// Test cases
|
30
|
+
type oneCase struct {
|
31
|
+
Description string
|
32
|
+
Property string
|
33
|
+
ListOne []int `json:"listOne"`
|
34
|
+
ListTwo []int `json:"listTwo"`
|
35
|
+
Expected sublist.Relation
|
36
|
+
}
|
37
|
+
|
38
|
+
// Template to generate test cases.
|
39
|
+
var tmpl = `package sublist
|
40
|
+
|
41
|
+
{{.Header}}
|
42
|
+
|
43
|
+
var testCases = []struct {
|
44
|
+
description string
|
45
|
+
listOne []int
|
46
|
+
listTwo []int
|
47
|
+
expected Relation
|
48
|
+
}{ {{range .J.Cases}}
|
49
|
+
{
|
50
|
+
description: {{printf "%q" .Description}},
|
51
|
+
listOne: {{printf "%#v" .ListOne}},
|
52
|
+
listTwo: {{printf "%#v" .ListTwo}},
|
53
|
+
expected: {{printf "%#v" .Expected}},
|
54
|
+
},{{end}}
|
55
|
+
}
|
56
|
+
`
|
@@ -0,0 +1,39 @@
|
|
1
|
+
# Sublist
|
2
|
+
|
3
|
+
Given two lists determine if the first list is contained within the second
|
4
|
+
list, if the second list is contained within the first list, if both lists are
|
5
|
+
contained within each other or if none of these are true.
|
6
|
+
|
7
|
+
Specifically, a list A is a sublist of list B if by dropping 0 or more elements
|
8
|
+
from the front of B and 0 or more elements from the back of B you get a list
|
9
|
+
that's completely equal to A.
|
10
|
+
|
11
|
+
Examples:
|
12
|
+
|
13
|
+
* A = [1, 2, 3], B = [1, 2, 3, 4, 5], A is a sublist of B
|
14
|
+
* A = [3, 4, 5], B = [1, 2, 3, 4, 5], A is a sublist of B
|
15
|
+
* A = [3, 4], B = [1, 2, 3, 4, 5], A is a sublist of B
|
16
|
+
* A = [1, 2, 3], B = [1, 2, 3], A is equal to B
|
17
|
+
* A = [1, 2, 3, 4, 5], B = [2, 3, 4], A is a superlist of B
|
18
|
+
* A = [1, 2, 4], B = [1, 2, 3, 4, 5], A is not a superlist of, sublist of or equal to B
|
19
|
+
|
20
|
+
## Running the tests
|
21
|
+
|
22
|
+
To run the tests run the command `go test` from within the exercise directory.
|
23
|
+
|
24
|
+
If the test suite contains benchmarks, you can run these with the `-bench`
|
25
|
+
flag:
|
26
|
+
|
27
|
+
go test -bench .
|
28
|
+
|
29
|
+
Keep in mind that each reviewer will run benchmarks on a different machine, with
|
30
|
+
different specs, so the results from these benchmark tests may vary.
|
31
|
+
|
32
|
+
## Further information
|
33
|
+
|
34
|
+
For more detailed information about the Go track, including how to get help if
|
35
|
+
you're having trouble, please visit the exercism.io [Go language page](http://exercism.io/languages/go/about).
|
36
|
+
|
37
|
+
|
38
|
+
## Submitting Incomplete Solutions
|
39
|
+
It's possible to submit an incomplete solution so you can see how others have completed the exercise.
|
@@ -0,0 +1,115 @@
|
|
1
|
+
package sublist
|
2
|
+
|
3
|
+
// Source: exercism/problem-specifications
|
4
|
+
// Commit: 71e24b5 sublist: Fix canonical-data.json formatting
|
5
|
+
// Problem Specifications Version: 1.0.0
|
6
|
+
|
7
|
+
var testCases = []struct {
|
8
|
+
description string
|
9
|
+
listOne []int
|
10
|
+
listTwo []int
|
11
|
+
expected Relation
|
12
|
+
}{
|
13
|
+
{
|
14
|
+
description: "empty lists",
|
15
|
+
listOne: []int{},
|
16
|
+
listTwo: []int{},
|
17
|
+
expected: "equal",
|
18
|
+
},
|
19
|
+
{
|
20
|
+
description: "empty list within non empty list",
|
21
|
+
listOne: []int{},
|
22
|
+
listTwo: []int{1, 2, 3},
|
23
|
+
expected: "sublist",
|
24
|
+
},
|
25
|
+
{
|
26
|
+
description: "non empty list contains empty list",
|
27
|
+
listOne: []int{1, 2, 3},
|
28
|
+
listTwo: []int{},
|
29
|
+
expected: "superlist",
|
30
|
+
},
|
31
|
+
{
|
32
|
+
description: "list equals itself",
|
33
|
+
listOne: []int{1, 2, 3},
|
34
|
+
listTwo: []int{1, 2, 3},
|
35
|
+
expected: "equal",
|
36
|
+
},
|
37
|
+
{
|
38
|
+
description: "different lists",
|
39
|
+
listOne: []int{1, 2, 3},
|
40
|
+
listTwo: []int{2, 3, 4},
|
41
|
+
expected: "unequal",
|
42
|
+
},
|
43
|
+
{
|
44
|
+
description: "false start",
|
45
|
+
listOne: []int{1, 2, 5},
|
46
|
+
listTwo: []int{0, 1, 2, 3, 1, 2, 5, 6},
|
47
|
+
expected: "sublist",
|
48
|
+
},
|
49
|
+
{
|
50
|
+
description: "consecutive",
|
51
|
+
listOne: []int{1, 1, 2},
|
52
|
+
listTwo: []int{0, 1, 1, 1, 2, 1, 2},
|
53
|
+
expected: "sublist",
|
54
|
+
},
|
55
|
+
{
|
56
|
+
description: "sublist at start",
|
57
|
+
listOne: []int{0, 1, 2},
|
58
|
+
listTwo: []int{0, 1, 2, 3, 4, 5},
|
59
|
+
expected: "sublist",
|
60
|
+
},
|
61
|
+
{
|
62
|
+
description: "sublist in middle",
|
63
|
+
listOne: []int{2, 3, 4},
|
64
|
+
listTwo: []int{0, 1, 2, 3, 4, 5},
|
65
|
+
expected: "sublist",
|
66
|
+
},
|
67
|
+
{
|
68
|
+
description: "sublist at end",
|
69
|
+
listOne: []int{3, 4, 5},
|
70
|
+
listTwo: []int{0, 1, 2, 3, 4, 5},
|
71
|
+
expected: "sublist",
|
72
|
+
},
|
73
|
+
{
|
74
|
+
description: "at start of superlist",
|
75
|
+
listOne: []int{0, 1, 2, 3, 4, 5},
|
76
|
+
listTwo: []int{0, 1, 2},
|
77
|
+
expected: "superlist",
|
78
|
+
},
|
79
|
+
{
|
80
|
+
description: "in middle of superlist",
|
81
|
+
listOne: []int{0, 1, 2, 3, 4, 5},
|
82
|
+
listTwo: []int{2, 3},
|
83
|
+
expected: "superlist",
|
84
|
+
},
|
85
|
+
{
|
86
|
+
description: "at end of superlist",
|
87
|
+
listOne: []int{0, 1, 2, 3, 4, 5},
|
88
|
+
listTwo: []int{3, 4, 5},
|
89
|
+
expected: "superlist",
|
90
|
+
},
|
91
|
+
{
|
92
|
+
description: "first list missing element from second list",
|
93
|
+
listOne: []int{1, 3},
|
94
|
+
listTwo: []int{1, 2, 3},
|
95
|
+
expected: "unequal",
|
96
|
+
},
|
97
|
+
{
|
98
|
+
description: "second list missing element from first list",
|
99
|
+
listOne: []int{1, 2, 3},
|
100
|
+
listTwo: []int{1, 3},
|
101
|
+
expected: "unequal",
|
102
|
+
},
|
103
|
+
{
|
104
|
+
description: "order matters to a list",
|
105
|
+
listOne: []int{1, 2, 3},
|
106
|
+
listTwo: []int{3, 2, 1},
|
107
|
+
expected: "unequal",
|
108
|
+
},
|
109
|
+
{
|
110
|
+
description: "same digits but different numbers",
|
111
|
+
listOne: []int{1, 0, 1},
|
112
|
+
listTwo: []int{10, 1},
|
113
|
+
expected: "unequal",
|
114
|
+
},
|
115
|
+
}
|