JavaScript (ES7), 108 bajtów
Pobiera dane wejściowe jako macierz znaków.
f=m=>(g=(y,X,V)=>m.map(r=>r.map((v,x)=>V?v>f&V>'a'>(x-X)**2+y*y-2?r[x]=n--:0:v<f?g(-y,x,v):n++)|y++))(n=0)|n
Wypróbuj online!
Podobnie jak w mojej pierwotnej odpowiedzi, ale wykonanie V>'a'>(x-X)**2+y*y-2jest w rzeczywistości 1 bajt krótsze niż użycie sztuczki heksadecymalnej opisanej poniżej. ¯ \ _ (ツ) _ / ¯
JavaScript (ES7), 109 bajtów
Pobiera dane wejściowe jako macierz znaków.
f=m=>(g=(y,X,V)=>m.map(r=>r.map((v,x)=>V?v>f&(x-X)**2+y*y<V-8?r[x]=n--:0:v<f?g(-y,x,'0x'+v):n++)|y++))(n=0)|n
Wypróbuj online!
W jaki sposób?
ZA1= ( x1, y1)ZA2)= ( x2), y2))
P ( A1, A2)) = ( x2)- x1)2)+ ( y2)- y1)2)
Biorąc pod uwagę współrzędne całkowite, wygląda to następująco:
8545852)12)541∙1452)12)585458
W związku z tym:
- ZA1ZA2)P ( A1, A2)) < 2
- ZA1ZA2)P ( A1, A2)) < 3
2)3)8
- ZA16- 810= 210
- b16- 810= 310
Skomentował
f = // named function, because we use it to test if a character
// is below or above 'm'
m => ( // m[] = input matrix
g = ( // g is a recursive function taking:
y, // y = offset between the reference row and the current row
X, // X = reference column
V // V = reference value, prefixed with '0x'
) => //
m.map(r => // for each row r[] in m[]:
r.map((v, x) => // for each value v at position x in r[]:
V ? // if V is defined:
v > f & // if v is equal to 'v'
(x - X) ** 2 + // and the quadrance between the reference point and
y * y // the current point
< V - 8 ? // is less than the reference value read as hexa minus 8:
r[x] = n-- // decrement n and invalidate the current cell
: // else:
0 // do nothing
: // else:
v < f ? // if v is either 'a' or 'b':
g( // do a recursive call:
-y, // pass the opposite of y
x, // pass x unchanged
'0x' + v // pass v prefixed with '0x'
) // end of recursive call
: // else:
n++ // increment n
) | y++ // end of inner map(); increment y
) // end of outer map()
)(n = 0) // initial call to g with y = n = 0
| n // return n