Ich habe eine einfache Rekursionsprozedur für DFS geschrieben.Segmentierungsfehler in DFS
#include <stdbool.h>
void mydfs(int ROWS, int COLS,char **A,int row, int col, bool **visited){
static int rowAdjacencyParams[4] = {-1,0,1,0};
static int colAdjacencyParams[4] = {0,1,0,-1};
*(*(visited+col)+row) = true;
//visited[row][col] = true;
int i,newR,newC;
for(i = 0;i<4;i++){
newR = row + rowAdjacencyParams[i];
newC = col + colAdjacencyParams[i];
if(((newR >=0) && (newR < ROWS)) && ((newC>=0) && (newC < COLS))){
/*if((A[newR][newC] == 'X') && !visited[newR][newC]){
mydfs(ROWS,COLS,A,newR,newC,visited);
}*/
}
}
}
int black(char** A, int n1) {
int i,j,count = 0;
int cols = strlen(A[0]);
bool visited[n1][cols];
memset(visited,0,sizeof(visited));
for(i = 0;i<n1;i++){
for(j = 0;j<cols;j++){
if((A[i][j] == 'X') && !visited[i][j]){
count++;
mydfs(n1,cols,A,i,j,visited);
}
}
}
return count;
}
int main(){
int ROWS = 3;
int COLS = 7;
char P[ROWS][COLS]= {"OOOXOOO","OOXXOXO","OXOOOXO"};
printf("Number of islands = %d",black(P,COLS));
return 0;
}
AKTUALISIERT Hauptfunktion
Allerdings, wenn ich dies ausführen es gibt mir eine segmentation fault
für Linie visited[row][col] = true;
. Dann habe ich versucht, es in *(*(visited+col)+row) = true;
zu ändern, aber immer noch den gleichen Segmentierungsfehlerfehler. Bitte erläutern Sie, warum ich diesen Fehler erhalte.
'bool besucht [n1] [cols];' Dies ist nicht legal C++. Wählen Sie auch eine Sprache - es ist entweder C++ oder C. Ich sehe das 'C++' in dem Code, den Sie gepostet haben, nicht. Wenn es C++ ist, könnte die Benutzung von 'std :: vector> anstelle von Doppelsternzeigern verwendet werden/sollte –
PaulMcKenzie
Auch eine a [mcve], also auch eine' main' Funktion, die das demonstriert Das Thema. – PaulMcKenzie
Das übergebene Array ist 2-D, das Funktionsargument ist ein Doppelstern. '* (* (visited + col) + row) = true;' hat keine Ahnung was die Zeilenlänge ist. Ich schlage vor, besucht + row * cols + col', oder vorzugsweise definieren Sie das Argument function, um mit dem Array übereinzustimmen, das Sie übergeben. –