Musical notes are are given the following 12 names, in ascending order:
A, A#, B, C, C#, D, D#, E, F, F#, G, G#
The names repeat for higher and lower notes,
so the note one step higher than "G#" is "A"
and the note 5 steps lower than "B" is "F#".
Notes that are a multiple of 12 steps apart have the same name, and for our purposes we will consider them equivalent.
Guitars have a number of strings, and each string is tuned to sound one of the 12 notes.
The note each string sounds is called its "open" note.
Underneath the strings are frets, numbered starting at 1, which are used to change the note a string sounds.
If you press a string against the i-th fret with your finger, the note will be i steps higher than the string's open note.
(i.e., if you press a string tuned to "C#" against the 3rd fret, it will sound the note "E").
Chords are sets of notes played at the same time.
To play a chord on a guitar, each string must sound one of the notes in the chord,
and each note in the chord must be played on at least one string.
There can be many ways to play the same chord.
We measure the difficulty of one way to play a chord as the amount you must stretch your fingers to reach the required frets.
Calculate this as the lowest fret used subtracted from the highest fret used, plus 1.
Only consider the strings which are pressed against frets -- the strings that are not pressed against frets (and, thus, sound their open note) do not affect the difficultly of a chord.
If a chord can be played without using any frets at all, its difficulty is zero.
You are given a String[] strings, each element of which is the open note of one string on the guitar,
and a String[] chord, each element of which is one note in a chord.
Return the lowest possible difficulty value necessary to play that chord.
|