mscroggs.co.uk
mscroggs.co.uk

subscribe

Blog

 2024-12-22 
I showed off and part-solved a prototype version of this puzzle with Katie Steckles in the fifteenth Finite Group livestream. You can watch a recording of this stream, and watch our future streams if you sign up to our Patreon.
I clearly haven't already made enough Christmas puzzles this year, so I've made another one. If you've used regular expressions before, head straight to mscroggs.co.uk/regexmas to try the puzzle. If you've not, read on...

What is a regular expression

Regular expressions are strings of characters that can be used in multiple programming languages to validate text. Regular expressions are usually written between two / characters. Between the slashes, characters have the following meaning:

The puzzle

My regular expression Christmas puzzle is shown below. You can either solve it on this page or at mscroggs.co.uk/regexmas using the buttons or your keyboard, or you can download this PDF of the puzzle.
In the grid below, write r, g, b, c, m, y, k, or w in every square so that:
The squares containing an r will be coloured red, those containing a g will be coloured green, those containing a b will be coloured blue, those containing a c will be coloured cyan, those containing an m will be coloured magenta, those containing a y will be coloured yellow, those containing a k will be coloured black, and those containing a w will be left white.
r g b c m y k w
/^w+yw+$/
/^([kw]+)[^kw]\1$/
/^(g|wwwg|gww)+.$/
/^wy?g*y+w+$/
/^((w|gg)(ww|g)){3}$/
/^[wg](w|g)[gw](.)\2+\1{2}$/
/^.g*[^y]$/
/^([gk][gk][gk])\1\1$/
/^yw+kw+y$/
/^w*b(bb)+w*$/
/^(w+)w?(bb?)\2\2\1$/
/^(www|bbb)+$/
/^w+gyw+$/
/^[wg]*y[wg]*$/
/^.*gwg.*gwb.*$/
/^[^g]+g+[^g]+$/
/^y?g+y?g+k?b+$/
/^[w]+g*w[^w]+$/
/^w+g+wg+[^g]+$/
/^w*yw*g+w*$/
/^w*y?g?y?w*$/
                        
(Click on one of these icons to react to this blog post)

You might also enjoy...

Comments

Comments in green were written by me. Comments in blue were not written by me.
 Add a Comment 


I will only use your email address to reply to your comment (if a reply is needed).

Allowed HTML tags: <br> <a> <small> <b> <i> <s> <sup> <sub> <u> <spoiler> <ul> <ol> <li> <logo>
To prove you are not a spam bot, please type "w" then "i" then "d" then "t" then "h" in the box below (case sensitive):

Archive

Show me a random blog post
 2026 

May 2026

World Cup stickers 2026

Apr 2026

A new puzzle every day
Mixing Wordle with other games

Feb 2026

Christmas (2025) is over
 2025 

Dec 2025

Christmas card 2025

Nov 2025

Christmas (2025) is coming!

Sep 2025

The partridge puzzle

Aug 2025

TMiP 2025 puzzle hunt

Jun 2025

A nonogram alphabet

Mar 2025

How to write a crossnumber

Jan 2025

Christmas (2024) is over
Friendly squares
 2024 

Dec 2024

A regular expression Christmas puzzle
Christmas card 2024

Nov 2024

Christmas (2024) is coming!

Feb 2024

Zines, pt. 2

Jan 2024

Christmas (2023) is over
 2023 
▼ show ▼
 2022 
▼ show ▼
 2021 
▼ show ▼
 2020 
▼ show ▼
 2019 
▼ show ▼
 2018 
▼ show ▼
 2017 
▼ show ▼
 2016 
▼ show ▼
 2015 
▼ show ▼
 2014 
▼ show ▼
 2013 
▼ show ▼
 2012 
▼ show ▼

Tags

edinburgh bodmas pokémon oeis coins gaussian elimination chebyshev bots ternary world cup european cup christmas thirteen dates anscombe's quartet manchester science festival recursion rhombicuboctahedron final fantasy sound go crossnumbers curvature logic 24 hour maths puzzles friendly squares big internet math-off bluesky light matt parker runge's phenomenon electromagnetic field bubble bobble weather station zines mathsjam advent calendar reddit dragon curves plastic ratio football error bars gather town raspberry pi crossnumber talking maths in public geogebra graph theory speed probability machine learning pascal's triangle hexapawn hannah fry menace simultaneous equations cambridge dinosaurs php triangles signorini conditions newcastle reuleaux polygons london underground hyperbolic surfaces alphabets map projections boundary element methods christmas card crochet inline code computational complexity golden ratio gerry anderson matrix of minors games pi logo crosswords draughts pizza cutting trigonometry weak imposition bempp squares martin gardner stirling numbers sorting wave scattering fence posts data databet pac-man national lottery kenilworth sobolev spaces realhats turtles regular expressions news live stream binary folding tube maps phd nonograms polynomials arithmetic finite group golden spiral royal institution flexagons palindromes people maths countdown exponential growth preconditioning london asteroids game show probability estimation python pythagoras logs braiding wordle video games chess interpolation warwick books fractals stickers matrix multiplication data visualisation royal baby inverse matrices numerical analysis misleading statistics numbers noughts and crosses accuracy mean sport wool nine men's morris rugby fonts craft mathsteroids latex graphs platonic solids ucl coventry frobel captain scarlet hats the aperiodical rust finite element method tennis geometry pokémon wordle manchester mathslogicbot harriss spiral radio 4 kings correlation chalkdust magazine standard deviation programming pi approximation day a gamut of games partridge puzzle determinants statistics folding paper tetris arrangement puzzles approximation propositional calculus game of life matrix of cofactors convergence datasaurus dozen quadrilaterals youtube errors cross stitch javascript dataset matrices guest posts tmip

Archive

Show me a random blog post
▼ show ▼
© Matthew Scroggs 2012–2026