JavaScript (ES7), 108 bayt
Girdiyi bir karakter matrisi olarak alır.
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
Çevrimiçi deneyin!
Orijinal cevabıma benzer, ancak yapmak V>'a'>(x-X)**2+y*y-2aslında aşağıda açıklanan altıgen hileyi kullanmaktan 1 bayt daha kısa. ¯ \ _ (ツ) _ / ¯
JavaScript (ES7), 109 bayt
Girdiyi bir karakter matrisi olarak alır.
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
Çevrimiçi deneyin!
Nasıl?
bir1= ( x1, y1)bir2=( x2,y2)
Q ( A1, A2) = ( x2- x1)2+ ( y2- y1)2
Tamsayı koordinatları göz önüne alındığında, aşağıdaki gibi görünür:
854585212541∙145212585458
Bu nedenle:
- bir1bir2Q ( A1, A2) < 2
- bir1bir2Q ( A1, A2) < 3
238
- bir16- 810= 210
- B16- 810= 310
Yorumlananlar
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