Constraint Specifications - code-golf/code-golf GitHub Wiki

(WIP - Improvements to wording, formatting, and information appreciated)

The goal of this page is to document the constraints of input holes on code.golf, including some details that may not be listed in the hole descriptions themselves. This page is not intended to list tips on solving holes, as the Hole-specific tips page already exists to do that.

On this page, [x..y] means the inclusive range from x to y.

ARGC - This page documents argc, the number of arguments for each hole. Although general constraints to holes rarely, if ever change, it is not uncommon for the number of arguments to a hole to sometimes be changed. As a result, solutions which hardcode argc may break over time. If you are editing a hole to add additional testcases, consider breaking it into multiple runs with the same argc as previous in order to avoid needlessly breaking solutions that hardcode argc.

RUNS - Some holes are "run" multiple times on different sets of inputs. What this means is that your code will be run independently on each set of inputs, and only be considered "passing" if it succeeds on all runs. Since these runs are completely separate, the number of runs has no direct effect on how your solution works, but it may still be useful to know what each run does. For example, the arguments of the hole "Emojify" are 25 ASCII emoticons. The hole is run 3 times: once with all 25 emoticons, and 2 more times with those inputs split into 2 groups of size 12 & 13.

Arabic to Roman

argc = 2000

Each argument is an integer in [1..3999]. Each number in this range appears once, split into 2 runs of 2000 arguments each.

Arrows

argc in [27, 30..90]

Each argument is a Unicode arrow pointing in 1 of 8 directions, or in no direction. The hole consists of 5 runs:

  • 1 run consisting of [1..3] of each of the 30 arrows, resulting in an argc anywhere in [30..90].
  • 4 runs where each contains only arrows pointing towards one of the 4 quadrants of the xy-plane. For example, a run with only these arrows ←⇐⇦↙↲⇙↓⇓⇩ for the negative-negative quadrant. 2 of these runs will have 3 of each arrow (argc = 27), the other 2 will have 4 of each arrow (argc = 36).

brainfuck

argc = 12

Each argument is a program in the brainfuck programming language which outputs a line of printable ASCII followed by a newline character. Each program:

  • Does not contain any characters which aren't brainfuck commands
  • Does not contain the brainfuck "read input" command (,)
  • Uses at most 27 memory cells left of the initial pointer location
  • Has length in [46..205]

CSS Colors

argc = 148

Each argument is the name of a color. The arguments form a full permutation of the 148 possible CSS color names.

Day of Week

(TO-DO)

DFA Simulator

(TO-DO)

Emojify

argc in [12, 13, 25]

Each argument is one of 25 ASCII emoticon. The first run has 25 arguments, forming a full permutation. The 2nd and 3rd arguments form a full permutation split into 2 runs of size 12 and 13.

Forsyth–Edwards Notation

(TO-DO)

Fractions

argc = 128

Each argument is a fraction in form num/denom, where num is in [0..250] and denom is in [1..250].

Game of Life

(TO-DO)

Hexdump

(TO-DO)

Intersection

argc in [107..276]

Each argument is eight space-separated integers, like x1 y1 w1 h1 x2 y2 w2 h2.

x1, y1, x2, and y2 are in [0..100].

w1, h1, w2, and h2 are in [1..50].

ISBN

argc = 100

Each argument is 10 numerical digits and 3 dashes, arranged in any of the following forms (where 0 can represent any digit):

  • 0-000-00000-
  • 0-0000-0000-
  • 0-00000-000-
  • 0-000000-00-
  • 0-0000000-0-

Jacobi Symbol

(TODO)

Levenshtein Distance

argc = 20

Each argument is a pair of space-separated lowercases words, each with [1..16] characters.

Lucky Tickets

argc = 20

Each argument is a pair of space-separated numbers like a b.

a is in [2..14].

b is an even number in [2..16].

Mahjong

(TO-DO)

Maze

argc = 1

There are 5 runs, each with a single 51x51 newline-separated maze (total length of input = 2651). The outside border of the maze is always solid walls (#). Mazes are designed with only one-char wide paths and walls (ie. 2x2 squares of solid walls or 2x2 blank squares do not occur).

Medal Tally

argc = 223

Each argument is a space-separated list of [1..10] integers, each in [1..98].

Morse Decoder

argc = 1 See Morse Encoder below, but encoded as Morse code.

Morse Encoder

argc = 1

A string is created containing 9 space-separated words: "BUD", "FOR", "JIGS", "NYMPH", "QUICK", "VEX", "WALTZ", the 10 numerical digits randomly arranged into a word, and the 26 uppercase letters randomly arranged into a word. This 72-character string is split into 2 parts of length 36, each of which as passed as the sole argument for a run.

Musical Chords

argc = 363

Each argument is a valid triad consisting of 3 space-separated pitch class names. Of the 372 possible triads, 9 are chosen at random to be dropped, and the remaining 363 are passed as arguments.

Ordinal Numbers

(TO-DO)

PalindromemordnilaP

(TO-DO)

Pangram Grep

argc = 76

Each argument is a string consisting of up to 79 printable ASCII characters [0x20..0x7e] (" ".."~").

Poker

argc = 37

Each argument is a hand of 5 poker cards [0x1f0al..0x1f0de] ("🂡".."🃞").

QR Decoder

argc = 1

The argument is a QR code which encodes 17 ASCII characters [0x21..0x7e] ("!".."~").

Repeating Decimals

(TO-DO)

Reverse Polish Notation

argc = 20

Each argument is [1..253] characters long. Each argument is a space-separated list of n integers and o operators, where n is in [1..32] and o = n - 1. Each integer is in [0..32676]. Operators can be any of +, -, /, *.

Reversi

(TO-DO)

Rock-paper-scissors-Spock-lizard

argc in [12, 13, 25]

Each argument is a unique repeated 2-permutation of the allowed plays. The first run consists of all 25 such permutations, the 2nd and 3rd runs consist of those permutations split into 2 runs of 12 and 13.

Roman to Arabic

argc = 2000

Each argument is an uppercase Roman representation of an integer in [1..3999]. Each number in this range appears once, split into 2 runs of 2000 arguments each.

Seven Segment

argc = 1

The argument contains 2 of each numerical digit.

SI Units

(TO-DO)

Spelling Numbers

argc = 1001

Each argument is a number in [0..1000]. The arguments form a full permutation of these numbers.

Star Wars Opening Crawl

argc = 9

Each argument consists of 2 space separated integers i and w, followed by the opening text crawls to one of the 9 Star Wars movies.

i is in [6..11]. w is in [14..49].

Sudoku

argc = 9

Each argument is a row of an unsolved Sudoku board, with "_" representing unsolved cells. There are at most 50 unsolved cells.

Sudoku v2

argc = 1

The input is a Unicode formatted Sudoku board with " " in unsolved cells. There are at most 50 unsolved cells.

Ten-pin Bowling

argc = 40

Each argument represents ten space-separated frames of bowling, and is right-padded with spaces if necessary to be 30 characters long.

Time Distance

argc = 321

Each argument is an integer in [-31535999999..31535999999]

Transpose Sentence

(TO-DO)

United States

argc in [25, 26, 51]

Each argument is a unique one of the 50 U.S. states plus District of Columbia. The first run is a full permutation of these 51 possibilities, the 2nd and 3rd runs consist of those permutations split into 2 runs of 25 and 26.

Zeckendorf Representation

(TO-DO)

Zodiac Signs

(TO-DO)