gpt4 book ai didi

c - DFS 中的段错误

转载 作者:行者123 更新时间:2023-11-30 15:07:48 26 4
gpt4 key购买 nike

我为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;
}

更新了主要功能

但是,当我运行此命令时,它会为 visited[row][col] = true; 行提供一个段错误。然后我尝试将其更改为 *(*(visited+col)+row) = true; 但仍然出现相同的段错误错误。请解释为什么我会收到此错误。

最佳答案

除了注释中指出的字符数据超出数组缓冲区之外,另一个错误是:

int black(char** A, int n1) {
//...
for(i = 0;i<n1;i++){
for(j = 0;j<cols;j++){
if((A[i][j] == 'X') && !visited[i][j]){ /* A[i] is out of bounds */

n1 作为列数传入,即 7。但是,如果您返回 main,您会看到:

int ROWS = 3;
int COLS = 7;

char P[ROWS][COLS]= {"OOOXOOO","OOXXOXO","OXOOOXO"};
printf("Number of islands = %d",black(P,COLS));

P 数组只有 3 行。因此,当调用 black 函数时,假设 P 有 7 行,而不是 3 行。这会导致 A 数组访问 A[0]A[1]A[2]、 (好),但随后 A[3] 等,这是未定义的行为(在您的情况下,是崩溃)。

因此您需要更正列/行逻辑。

<小时/>

我要告诉你一个 secret 。由于您最初将问题标记为 C++,所以我花时间将那些双星更改为 std::vector ,并使用 at() 函数来定位问题。我知道您现在已将您的问题标记为 C99,但我只是想知道为什么标记很重要。不知道C99有没有这种自动检测边界条件的功能。

关于c - DFS 中的段错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37925582/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com