我解决了它,并且部分起作用了,但是我只能使用BFS找到解决方案,并且我确定这不需要图遍历算法,因为我们还没有完成,但是我找不到任何其他解决方案。有人可以给我一个提示。我将BFS代码发布到我实际上是如何解决的,而不是我认为应该如何解决的。
#include <stdio.h>
#include <stdlib.h>
char file[20][20];
int v[20], ns, n, comp, c[20];
int prim;
int ultim;
FILE *f;
int nr = 0, nl, nc;
void matrix() {
int i, j;
char c, n;
fscanf(f, "%d %d \n", &nl, &nc);
for (i = 1; i <= nl; i++) {
for (j = 1; j <= nc; j++) {
c = getc(f);
file[i][j] = c;
}
n = getc(f);
}
}
// citirea grafului din fisier text si construirea matricei de adiacenta
// afisarea pe ecran a matricei de adiacenta
void afisare() {
int i, j;
printf("Matricea : \n");
for (i = 1; i <= nl; i++)
{
for (j = 1; j <= nc; j++)
printf("%c", file[i][j]);
printf("\n");
}
}
// returnează primului nod nevizitat
int exista_nod_nevizitat(int v[20], int n) {
int i, j;
for (i = 1; i <= nl; i++)
if (v[i] == 0)
return i; // primul nod nevizitat
return 0; // nu mai exista noduri nevizitate
}
// parcurgerea în latime a unei componente conexe, plecând din nodul de start ns
void parcurgere_latime(char file[20][20], int nl, int ns) {
int i, j;
comp++;
v[ns] = 1;
prim = ultim = 1;
c[ultim] = ns;
while (prim <= ultim) {
for (i = 1; i <= nl; i++)
if (file[c[prim]][i] == 'L')
if (v[i] == 0)
{
ultim++;
c[ultim] = i;
v[i] = 1;
}
prim++;
}
}
// functia principala main()
int main() {
int set, nr;
f = fopen("in1.txt", "r");
fscanf(f, "%d \n", &set);
while (set != 0) {
matrix();
afisare();
while (exista_nod_nevizitat(v, n) != 0) {
ns = exista_nod_nevizitat(v, n);
parcurgere_latime(file, n, ns); // parcurg o alta componenta conexa
}
printf("Graful este alcătuit din ");
printf("%d", comp);
printf("componente conexe \n");
set--;
}
return 0;
}
答案 0 :(得分:2)
找到了似乎更简单,更快捷的解决方案
int countIslands(char a[100][100])
{
int count = 0;
for ( i=0; i<nl; i++)
{
for (j=0; j<nc; j++)
{
if (a[i][j] == 'L')
{
if ((i == 0 || a[i-1][j] == '.') &&
(j == 0 || a[i][j-1] == '.'))
count++;
}
}
}
return count;
}
答案 1 :(得分:0)
我将提出一个非常基本的解决方案。请注意,它不一定不是最佳方法,并且有点蛮力。
基本上,我想的是逐个遍历矩阵,每次找到一个L(该岛的起点)时,都要从邻居到邻居并用数字N来标记它的边界。当前岛,直到该岛的元素不再有邻居为止,然后继续遍历矩阵,每次找到未标记的L时都重复相同的步骤。