Policz sąsiednie podmacierze

12

Przeniesiono z czatu

Biorąc pod uwagę dwa niepusty nieujemną liczbą całkowitą macierzy i B , odpowiedzi na liczbę występuje jako ciągły, ewentualnie pokrywające, podmatryca w B .

Przykłady / zasady

0. Mogą nie być żadnych podmacierzy

Odp . :
[[3,1],
[1,4]]

B :
[[1,4],
[3,1]]

Odpowiedź:
0

1. Submatrices muszą być ciągłe

Odp . :
[[1,4],
[3,1]]

B :
[[3,1,4,0,5],
[6,3,1,0,4],
[5,6,3,0,1]]

Odpowiedź:
1(zaznaczono pogrubioną czcionką)

2. Submatrices mogą się pokrywać

Odp . :
[[1,4],
[3,1]]

B :
[[3,1,4,5],
[6,3,1,4],
[5,6,3,1]]

Odpowiedź:
2(zaznaczone odpowiednio pogrubioną czcionką i kursywą)

3. Matryca (pod) może mieć rozmiar od 1 do 1 i więcej

Odp . :
[[3]]

B :
[[3,1,4,5],
[6,3,1,4],
[5,6,3,1]]

Odpowiedź:
3(zaznaczono pogrubioną czcionką)

4. Macierze mogą mieć dowolny kształt

Odp . :
[[3,1,3]]

[[3,1,3,1,3,1,3,1,3]]

Odpowiedź:
4(dwie pogrubione, dwie kursywa)

Adám
źródło

Odpowiedzi:

6

Brachylog (v2), 10 bajtów

{{s\s\}ᵈ}ᶜ

Wypróbuj online!

Podoba mi się, jak przejrzysty i prosty jest ten program w Brachylog; niestety nie jest to tak krótki bajt, ponieważ składnia metapredykatu zajmuje trzy bajty i musi zostać użyta dwukrotnie w tym programie.

Wyjaśnienie

{{s\s\}ᵈ}ᶜ
  s         Contiguous subset of rows
   \s\      Contiguous subset of columns (i.e. transpose, subset rows, transpose)
 {    }ᵈ    The operation above transforms the first input to the second input
{       }ᶜ  Count the number of ways in which this is possible
ais523
źródło
5

Galaretka , 7 bajtów

ZẆ$⁺€Ẏċ

Wypróbuj online!

Jak to działa

ZẆ$⁺€Ẏċ  Main link. Arguments: B, A

  $      Combine the two links to the left into a monadic chain.
Z          Zip; transpose the matrix.
 Ẇ         Window; yield all contiguous subarrays of rows.
   ⁺     Duplicate the previous link chain.
    €    Map it over the result of applying it to B.
         This generates all contiguous submatrices of B, grouped by the selected
         columns of B.
     Ẏ   Tighten; dump all generated submatrices in a single array.
      ċ  Count the occurrences of A.
Dennis
źródło
4

MATL , 12 bajtów

ZyYC2MX:=XAs

Wejścia są , a następnie B .

Wypróbuj online! Lub sprawdź wszystkie przypadki testowe .

Wyjaśnienie

Rozważmy wejść [1,4; 3 1], [3,1,4,5; 6,3,1,4; 5,6,3,1]. Stos pokazano poniżej z najnowszym elementem.

Zy    % Implicit input: A. Push size as a vector of two numbers
      % STACK: [2 2]
YC    % Implicit input: B. Arrange sliding blocks of specified size as columns,
      % in column-major order
      % STACK: [3 6 1 3 4 1;
                6 5 3 6 1 3;
                1 3 4 1 5 4;
                3 6 1 3 4 1]
2M    % Push input to second to last function again; that is, A
      % STACK: [3 6 1 3 4 1;
                6 5 3 6 1 3;
                1 3 4 1 5 4;
                3 6 1 3 4 1],
               [1 4;
                3 1]                    
X:    % Linearize to a column vector, in column-major order
      % STACK: [3 6 1 3 4 1;
                6 5 3 6 1 3;
                1 3 4 1 5 4;
                3 6 1 3 4 1],
               [1;
                3;
                4;
                1]  
=     % Test for equality, element-wise with broadcast
      % STACK: [0 0 1 0 0 1
                0 0 1 0 0 1;
                0 0 1 0 0 1;
                0 0 1 0 0 1]
XA    % True for columns containing all true values
      % STACK: [0 0 1 0 0 1]
s     % Sum. Implicit display
      % STACK: 2
Luis Mendo
źródło
2

05AB1E , 10 bajtów

øŒεøŒI.¢}O

Wypróbuj online!

øŒεøŒI.¢}O     Full program. Takes 2 matrices as input. First B, then A.
øŒ             For each column of B, take all its sublists.
  ε     }      And map a function through all those lists of sublists.
   øŒ          Transpose the list and again generate all its sublists.
               This essentially computes all sub-matrices of B.
     I.¢       In the current collection of sub-matrices, count the occurrences of A.
         O     At the end of the loop sum the results.
Pan Xcoder
źródło
2

Dyalog APL, 6 4 bajtów

≢∘⍸⍷

To prawie wbudowane (dzięki H.PWiz i ngn ).

  ⍷       Binary matrix containing locations of left argument in right argument
≢∘⍸       Size of the array of indices of 1s

Alternatywne niezintegrowane:

{+/,((*⍺)≡⊢)⌺(⍴⍺)*⍵}

Funkcja dyadyczna, która pobiera dużą tablicę po prawej stronie i podtablicę po lewej stronie.

                  *⍵       exp(⍵), to make ⍵ positive.
    ((*⍺)≡⊢)⌺(⍴⍺)        Stencil;
                            all subarrays of ⍵ (plus some partial subarrays
                            containing 0, which we can ignore)
               ⍴⍺             of same shape as ⍺
     (*⍺)≡⊢                   processed by checking whether they're equal to exp(⍺).
                           Result is a matrix of 0/1.
   ,                     Flatten
 +/                      Sum.

Wypróbuj tutaj .

lirtosiast
źródło
Powinieneś kasę
H.PWiz
możesz użyć funkcji compose ( ), aby skrócić pociąg: +/∘∊⍷lub nawet≢∘⍸⍷
ngn
1

JavaScript (ES6), 93 bajty

Pobiera dane wejściowe jako (A)(B).

a=>b=>b.map((r,y)=>r.map((_,x)=>s+=!a.some((R,Y)=>R.some((v,X)=>v!=(b[y+Y]||0)[x+X]))),s=0)|s

Wypróbuj online!

Arnauld
źródło
1

R , 95 bajtów

function(A,B,x=dim(A),D=dim(B)-x){for(i in 0:D)for(j in 0:D[2])F=F+all(B[1:x+i,1:x[2]+j]==A);F}

Wypróbuj online!

digEmAll
źródło
1

Czysty , 118 97 95 bajtów

import StdEnv,Data.List
?x=[transpose y\\z<-tails x,y<-inits z]
$a b=sum[1\\x<- ?b,y<- ?x|y==a]

Wypróbuj online!

Obrzydliwe
źródło
1

Węgiel drzewny , 36 27 bajtów

IΣ⭆η⭆ι⁼θE✂ηκ⁺Lθκ¹✂νμ⁺L§θ⁰μ¹

Wypróbuj online! Znacznie krócej, gdy Equals znów działa dla tablic. Wyjaśnienie:

   η                        Input array B
  ⭆                         Mapped over rows and joined
     ι                      Current row
    ⭆                       Mapped over columns and joined
       θ                    Input array A
      ⁼                     Is equal to
          η                 Input array B
         ✂                  Sliced
                ¹           All elements from
           κ                Current row index to
             L              Length of
              θ             Input array A
            ⁺               Plus
               κ            Current row index
        E                   Mapped over rows
                  ν         Current inner row
                 ✂          Sliced
                          ¹ All elements from
                   μ        Current column index to
                     L      Length of
                       θ    Input array A
                      §     Indexed by
                        ⁰   Literal 0
                    ⁺       Plus
                         μ  Current column index
 Σ                          Digital sum
I                           Cast to string
                            Implicitly printed
Neil
źródło
0

Python 2 , 211 bajtów

a,b=input()
l,w,L,W,c=len(a),len(a[0]),len(b),len(b[0]),0
for i in range(L):
 for j in range(W):
  if j<=W-w and i<=L-l:
   if not sum([a[x][y]!=b[i+x][j+y]for x in range(l)for y in range(w)]):
    c+=1
print c 

Wypróbuj online!

Dość bezpośredni. Przejdź przez większą matrycę i sprawdź, czy mniejsza matryca może się zmieścić.

Jedynym nawet nieco trudnym krokiem jest zrozumienie listy w szóstej linii, która opiera się na konwencjach Pythona do mieszania arytmetyki logicznej i całkowitej.

CCB60
źródło
0

Groovy , 109 bajtów

{a,b->(0..<b.size()).sum{i->(0..<b[i].size()).count{j->k=i-1
a.every{l=j;k++
it.every{(b[k]?:b)[l++]==it}}}}}

Wypróbuj online!

Tylko ASCII
źródło
0

Scala , 151 bajtów

(a,b)=>{(0 to b.size-a.size).map(i=>(0 to b(0).size-a(0).size).count(j=>{var k=i-1
a.forall(c=>{var l=j-1;k+=1
c.forall(d=>{l+=1
b(k)(l)==d})})})).sum}

Wypróbuj online!

Tylko ASCII
źródło