计算具有相同数量的相邻晶格的晶格数

时间:2013-07-13 17:33:21

标签: c++ c algorithm

我在一个名为“Lattice.txt”的文件中有一组格子坐标。我的代码检查每个晶格的邻居数 -

void CheckLattice(int b)
{
   vector<Lattice> lattices;

   /* reading from file logic */
   ifstream theFile("Lattice.txt");
   double x1,y1,x2,y2;
   while (theFile >> x1 >> y1 >> x2 >> y2) {
      lattices.push_back(Lattice(x1,y1, x2,y2));
   }

   /* counting neighbors logic */
   int lattice_count = 0;
   int GroupLattice=0;
   for (int x = 0; x < lattices.size(); ++x) {
      if (lattices[b].NearestLattice(lattices[x])) {
         if (x==b) {
            continue; //this is our lattice , skip it.
         }
         lattice_count++;
      }
      GroupLattice++;
   }

   cout<<"Lattice "<<(b+1)<<" has = "<<lattice_count<<" neighbours "<<endl;
   cout << " The number of lattice with "<< lattice_count << " neighbours are " << GroupLattice << endl;
   cout << endl;

}

int main()
{
   int neighbour=0; 
   for(int i=0; i<10; i++){
      CheckLattice(i);
   }

   return 0;
}

它返回这样的值 -

Lattice 1 has = 7 neighbours 
 The number of lattice with 7 neighbours are 14

Lattice 2 has = 3 neighbours 
 The number of lattice with 3 neighbours are 15

Lattice 3 has = 8 neighbours 
 The number of lattice with 8 neighbours are 14

Lattice 4 has = 6 neighbours 
 The number of lattice with 6 neighbours are 15

Lattice 5 has = 8 neighbours 
 The number of lattice with 8 neighbours are 14

Lattice 6 has = 8 neighbours 
 The number of lattice with 8 neighbours are 15

Lattice 7 has = 8 neighbours 
 The number of lattice with 8 neighbours are 14

Lattice 8 has = 1 neighbours 
 The number of lattice with 1 neighbours are 15

Lattice 9 has = 7 neighbours 
 The number of lattice with 7 neighbours are 14

Lattice 10 has = 5 neighbours 
 The number of lattice with 5 neighbours are 15

虽然这段代码正确地返回每个格子的邻居数,但它不会返回具有相同邻居数量的格子总数的值。 相反,它只返回14或15!我该如何解决?

我希望输出像这样 -

Lattice 1 has = 7 neighbours 

Lattice 2 has = 3 neighbours 

Lattice 3 has = 8 neighbours 

Lattice 4 has = 6 neighbours 

Lattice 5 has = 8 neighbours 

Lattice 6 has = 8 neighbours 

Lattice 7 has = 8 neighbours 

Lattice 8 has = 1 neighbours 

Lattice 9 has = 7 neighbours 

Lattice 10 has = 5 neighbours 

 The number of lattice with 1 neighbours are 1
 The number of lattice with 2 neighbours are 1
 The number of lattice with 7 neighbours are 2
 The number of lattice with 8 neighbours are 4 ...etc

我可能错过了什么。任何人都可以帮我吗?

1 个答案:

答案 0 :(得分:0)

它没有打印具有相同数量的邻居的格子数的原因是因为你根本没有逻辑来看lattices[x]是否具有与lattices[b]相同数量的邻居,你可以将每个格子都击中continue

事实上,您还没有存储lattice[x]所拥有的邻居数量。

我建议您将代码重新组织为

  • 将文件中的数据读入一个持续整个程序的数据结构
  • 计算每个网格具有的邻居数量,使用网格存储该值并将其打印
  • 使用存储的邻居数完成任务