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,49 @@
|
|
1
|
+
package sublist
|
2
|
+
|
3
|
+
import "reflect"
|
4
|
+
|
5
|
+
// Relation is the comparison between lists
|
6
|
+
type Relation string
|
7
|
+
|
8
|
+
// Possible relations
|
9
|
+
const (
|
10
|
+
RelationEqual Relation = "equal"
|
11
|
+
RelationSublist Relation = "sublist"
|
12
|
+
RelationSuperlist Relation = "superlist"
|
13
|
+
RelationUnequal Relation = "unequal"
|
14
|
+
)
|
15
|
+
|
16
|
+
// Sublist checks difference of two lists and
|
17
|
+
// returns equal, sublist, superlist or unequal according
|
18
|
+
// to their relation to each other.
|
19
|
+
func Sublist(l1, l2 []int) Relation {
|
20
|
+
if reflect.DeepEqual(l1, l2) {
|
21
|
+
return RelationEqual
|
22
|
+
} else if contains(l1, l2) {
|
23
|
+
return RelationSuperlist
|
24
|
+
} else if contains(l2, l1) {
|
25
|
+
return RelationSublist
|
26
|
+
}
|
27
|
+
return RelationUnequal
|
28
|
+
}
|
29
|
+
|
30
|
+
func contains(l1, l2 []int) bool {
|
31
|
+
if len(l2) == 0 {
|
32
|
+
return true
|
33
|
+
} else if len(l2) > len(l1) {
|
34
|
+
return false
|
35
|
+
}
|
36
|
+
for i := 0; i <= len(l1)-len(l2); i++ {
|
37
|
+
if l1[i] != l2[0] {
|
38
|
+
continue
|
39
|
+
}
|
40
|
+
rest := true
|
41
|
+
for j, e := range l2 {
|
42
|
+
rest = rest && l1[i+j] == e
|
43
|
+
}
|
44
|
+
if rest {
|
45
|
+
return true
|
46
|
+
}
|
47
|
+
}
|
48
|
+
return false
|
49
|
+
}
|
@@ -0,0 +1,22 @@
|
|
1
|
+
package sublist
|
2
|
+
|
3
|
+
import (
|
4
|
+
"testing"
|
5
|
+
)
|
6
|
+
|
7
|
+
func TestSublist(t *testing.T) {
|
8
|
+
for _, tc := range testCases {
|
9
|
+
if actual := Sublist(tc.listOne, tc.listTwo); 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 BenchmarkSublist(b *testing.B) {
|
17
|
+
for i := 0; i < b.N; i++ {
|
18
|
+
for _, tc := range testCases {
|
19
|
+
Sublist(tc.listOne, tc.listTwo)
|
20
|
+
}
|
21
|
+
}
|
22
|
+
}
|
@@ -1,8 +1,8 @@
|
|
1
1
|
package summultiples
|
2
2
|
|
3
|
-
// Source: exercism/
|
4
|
-
// Commit:
|
5
|
-
//
|
3
|
+
// Source: exercism/problem-specifications
|
4
|
+
// Commit: df076b2 sum-of-multiples: Add up to 7 test case (#896)
|
5
|
+
// Problem Specifications Version: 1.1.0
|
6
6
|
|
7
7
|
var varTests = []struct {
|
8
8
|
divisors []int
|
@@ -11,6 +11,7 @@ var varTests = []struct {
|
|
11
11
|
}{
|
12
12
|
{[]int{3, 5}, 1, 0}, // multiples of 3 or 5 up to 1
|
13
13
|
{[]int{3, 5}, 4, 3}, // multiples of 3 or 5 up to 4
|
14
|
+
{[]int{3}, 7, 9}, // multiples of 3 up to 7
|
14
15
|
{[]int{3, 5}, 10, 23}, // multiples of 3 or 5 up to 10
|
15
16
|
{[]int{3, 5}, 100, 2318}, // multiples of 3 or 5 up to 100
|
16
17
|
{[]int{3, 5}, 1000, 233168}, // multiples of 3 or 5 up to 1000
|
@@ -2,14 +2,6 @@ package summultiples
|
|
2
2
|
|
3
3
|
import "testing"
|
4
4
|
|
5
|
-
const targetTestVersion = 2
|
6
|
-
|
7
|
-
func TestTestVersion(t *testing.T) {
|
8
|
-
if testVersion != targetTestVersion {
|
9
|
-
t.Fatalf("Found testVersion = %v, want %v", testVersion, targetTestVersion)
|
10
|
-
}
|
11
|
-
}
|
12
|
-
|
13
5
|
func TestSumMultiples(t *testing.T) {
|
14
6
|
for _, test := range varTests {
|
15
7
|
s := SumMultiples(test.limit, test.divisors...)
|
@@ -11,11 +11,6 @@ import (
|
|
11
11
|
//
|
12
12
|
// Note that unlike other tracks the Go version of the tally function
|
13
13
|
// should not ignore errors. It's not idiomatic Go to ignore errors.
|
14
|
-
//
|
15
|
-
// Also define a testVersion with a value that matches
|
16
|
-
// the targetTestVersion here.
|
17
|
-
|
18
|
-
const targetTestVersion = 4
|
19
14
|
|
20
15
|
var _ func(io.Reader, io.Writer) error = Tally
|
21
16
|
|
@@ -110,12 +105,6 @@ var errorTestCases = []string{
|
|
110
105
|
"Devastating Donkeys;Allegoric Alaskians;dra",
|
111
106
|
}
|
112
107
|
|
113
|
-
func TestTestVersion(t *testing.T) {
|
114
|
-
if testVersion != targetTestVersion {
|
115
|
-
t.Fatalf("Found testVersion = %v, want %v", testVersion, targetTestVersion)
|
116
|
-
}
|
117
|
-
}
|
118
|
-
|
119
108
|
func TestTallyHappy(t *testing.T) {
|
120
109
|
for _, tt := range happyTestCases {
|
121
110
|
reader := strings.NewReader(tt.input)
|
@@ -1,8 +1,8 @@
|
|
1
1
|
package transpose
|
2
2
|
|
3
|
-
// Source: exercism/
|
3
|
+
// Source: exercism/problem-specifications
|
4
4
|
// Commit: 6dba022 transpose: Fix canonical-data.json formatting
|
5
|
-
//
|
5
|
+
// Problem Specifications Version: 1.0.0
|
6
6
|
|
7
7
|
var testCases = []struct {
|
8
8
|
description string
|
@@ -5,14 +5,6 @@ import (
|
|
5
5
|
"testing"
|
6
6
|
)
|
7
7
|
|
8
|
-
const targetTestVersion = 1
|
9
|
-
|
10
|
-
func TestTestVersion(t *testing.T) {
|
11
|
-
if testVersion != targetTestVersion {
|
12
|
-
t.Fatalf("Found testVersion = %v, want %v", testVersion, targetTestVersion)
|
13
|
-
}
|
14
|
-
}
|
15
|
-
|
16
8
|
func TestTranspose(t *testing.T) {
|
17
9
|
for _, test := range testCases {
|
18
10
|
actual := Transpose(test.input)
|
@@ -10,11 +10,6 @@ import (
|
|
10
10
|
// Define a function Build(records []Record) (*Node, error)
|
11
11
|
// where Record is a struct containing int fields ID and Parent
|
12
12
|
// and Node is a struct containing int field ID and []*Node field Children.
|
13
|
-
//
|
14
|
-
// Also define a testVersion with a value that matches
|
15
|
-
// the targetTestVersion here.
|
16
|
-
|
17
|
-
const targetTestVersion = 4
|
18
13
|
|
19
14
|
var successTestCases = []struct {
|
20
15
|
name string
|
@@ -210,12 +205,6 @@ func (n Node) String() string {
|
|
210
205
|
return fmt.Sprintf("%d:%s", n.ID, n.Children)
|
211
206
|
}
|
212
207
|
|
213
|
-
func TestTestVersion(t *testing.T) {
|
214
|
-
if testVersion != targetTestVersion {
|
215
|
-
t.Fatalf("Found testVersion = %v, want %v", testVersion, targetTestVersion)
|
216
|
-
}
|
217
|
-
}
|
218
|
-
|
219
208
|
func TestMakeTreeSuccess(t *testing.T) {
|
220
209
|
for _, tt := range successTestCases {
|
221
210
|
actual, err := Build(tt.input)
|
@@ -0,0 +1,10 @@
|
|
1
|
+
## Constant Declarations
|
2
|
+
|
3
|
+
In this exercise you are asked to declare a series of constants used to identify
|
4
|
+
different types of triangles. Pick the data type you think works best for this
|
5
|
+
and get the tests passing.
|
6
|
+
|
7
|
+
Afterwards, it may be worth reading about Go's
|
8
|
+
predeclared identifier [iota](https://golang.org/ref/spec#Iota). There's an
|
9
|
+
excellent write up about it
|
10
|
+
[here](https://splice.com/blog/iota-elegant-constants-golang/).
|
@@ -1,16 +1,28 @@
|
|
1
|
-
|
1
|
+
// This is a "stub" file. It's a little start on your solution.
|
2
|
+
// It's not a complete solution though; you have to write some code.
|
2
3
|
|
3
|
-
|
4
|
+
// Package twofer should have a package comment that summarizes what it's about.
|
5
|
+
// https://golang.org/doc/effective_go.html#commentary
|
6
|
+
package triangle
|
4
7
|
|
5
|
-
func KindFromSides(a, b, c float64) Kind
|
6
8
|
|
7
9
|
// Notice KindFromSides() returns this type. Pick a suitable data type.
|
8
10
|
type Kind
|
9
11
|
|
10
|
-
|
11
|
-
|
12
|
-
|
13
|
-
|
14
|
-
|
12
|
+
const (
|
13
|
+
// Pick values for the following identifiers used by the test program.
|
14
|
+
NaT // not a triangle
|
15
|
+
Equ // equilateral
|
16
|
+
Iso // isosceles
|
17
|
+
Sca // scalene
|
18
|
+
)
|
15
19
|
|
16
|
-
//
|
20
|
+
// ShareWith should have a comment documenting it.
|
21
|
+
func KindFromSides(a, b, c float64) Kind {
|
22
|
+
// Write some code here to pass the test suite.
|
23
|
+
// Then remove all the stock comments.
|
24
|
+
// They're here to help you get started but they only clutter a finished solution.
|
25
|
+
// If you leave them in, reviewers may protest!
|
26
|
+
var k Kind
|
27
|
+
return k
|
28
|
+
}
|
@@ -5,8 +5,6 @@ import (
|
|
5
5
|
"testing"
|
6
6
|
)
|
7
7
|
|
8
|
-
const targetTestVersion = 3
|
9
|
-
|
10
8
|
type testCase struct {
|
11
9
|
want Kind
|
12
10
|
a, b, c float64
|
@@ -53,12 +51,6 @@ func init() {
|
|
53
51
|
testData = append(testData, nf[1:]...)
|
54
52
|
}
|
55
53
|
|
56
|
-
func TestTestVersion(t *testing.T) {
|
57
|
-
if testVersion != targetTestVersion {
|
58
|
-
t.Fatalf("Found testVersion = %v, want %v", testVersion, targetTestVersion)
|
59
|
-
}
|
60
|
-
}
|
61
|
-
|
62
54
|
// Test that the kinds are not equal to each other.
|
63
55
|
// If they are equal, then TestKind will return false positives.
|
64
56
|
func TestKindsNotEqual(t *testing.T) {
|
@@ -2,8 +2,6 @@ package trinary
|
|
2
2
|
|
3
3
|
import "testing"
|
4
4
|
|
5
|
-
const targetTestVersion = 1
|
6
|
-
|
7
5
|
var tests = []struct {
|
8
6
|
arg string
|
9
7
|
want int64
|
@@ -20,12 +18,6 @@ var tests = []struct {
|
|
20
18
|
{"2021110011022210012102010021220101220222", 0, false},
|
21
19
|
}
|
22
20
|
|
23
|
-
func TestTestVersion(t *testing.T) {
|
24
|
-
if testVersion != targetTestVersion {
|
25
|
-
t.Fatalf("Found testVersion = %v, want %v.", testVersion, targetTestVersion)
|
26
|
-
}
|
27
|
-
}
|
28
|
-
|
29
21
|
func TestParseTrinary(t *testing.T) {
|
30
22
|
for _, test := range tests {
|
31
23
|
switch res, err := ParseTrinary(test.arg); {
|
@@ -6,8 +6,6 @@ import (
|
|
6
6
|
"testing"
|
7
7
|
)
|
8
8
|
|
9
|
-
const targetTestVersion = 1
|
10
|
-
|
11
9
|
type testCase struct {
|
12
10
|
input int
|
13
11
|
expected string
|
@@ -52,12 +50,6 @@ func diff(got, want string) string {
|
|
52
50
|
}
|
53
51
|
}
|
54
52
|
|
55
|
-
func TestTestVersion(t *testing.T) {
|
56
|
-
if testVersion != targetTestVersion {
|
57
|
-
t.Fatalf("Found testVersion = %v, want %v.", testVersion, targetTestVersion)
|
58
|
-
}
|
59
|
-
}
|
60
|
-
|
61
53
|
func TestSong(t *testing.T) {
|
62
54
|
var expected = ""
|
63
55
|
for _, test := range testCases {
|
@@ -5,11 +5,11 @@
|
|
5
5
|
// https://golang.org/doc/effective_go.html#commentary
|
6
6
|
package twofer
|
7
7
|
|
8
|
-
// ShareWith
|
8
|
+
// ShareWith should have a comment documenting it.
|
9
9
|
func ShareWith(string) string {
|
10
10
|
// Write some code here to pass the test suite.
|
11
11
|
// Then remove all the stock comments.
|
12
12
|
// They're here to help you get started but they only clutter a finished solution.
|
13
|
-
// If you leave them in, reviewers
|
13
|
+
// If you leave them in, reviewers may protest!
|
14
14
|
return ""
|
15
15
|
}
|
@@ -1,8 +1,8 @@
|
|
1
1
|
package variablelengthquantity
|
2
2
|
|
3
|
-
// Source: exercism/
|
3
|
+
// Source: exercism/problem-specifications
|
4
4
|
// Commit: d6a62f7 variable-length-quantity: Fix canonical-data.json formatting
|
5
|
-
//
|
5
|
+
// Problem Specifications Version: 1.0.0
|
6
6
|
|
7
7
|
// Encode a series of integers, producing a series of bytes.
|
8
8
|
var encodeTestCases = []struct {
|
@@ -6,14 +6,6 @@ import (
|
|
6
6
|
"testing"
|
7
7
|
)
|
8
8
|
|
9
|
-
const targetTestVersion = 4
|
10
|
-
|
11
|
-
func TestTestVersion(t *testing.T) {
|
12
|
-
if testVersion != targetTestVersion {
|
13
|
-
t.Fatalf("Found testVersion = %v, want %v.", testVersion, targetTestVersion)
|
14
|
-
}
|
15
|
-
}
|
16
|
-
|
17
9
|
func TestDecodeVarint(t *testing.T) {
|
18
10
|
for i, tc := range decodeTestCases {
|
19
11
|
o, err := DecodeVarint(tc.input)
|
@@ -1,8 +1,8 @@
|
|
1
1
|
package wordcount
|
2
2
|
|
3
|
-
// Source: exercism/
|
3
|
+
// Source: exercism/problem-specifications
|
4
4
|
// Commit: cd26d49 word-count: Make exercise schema-compliant (#634)
|
5
|
-
//
|
5
|
+
// Problem Specifications Version: 1.0.0
|
6
6
|
|
7
7
|
var testCases = []struct {
|
8
8
|
description string
|