笔试算法题:求6*7网格中的黑点分布

时间:2023-04-05 02:31:46 笔试题目 我要投稿
  • 相关推荐

笔试算法题:求6*7网格中的黑点分布

  求网格中的黑点分布。现有6*7的网格,在某些格子中有黑点,已知各行与各列中有黑点的点数之和,请在这张网格中画出黑点的位置。(这是一网友提出的题目,说是他笔试时遇到算法题)

笔试算法题:求6*7网格中的黑点分布

  #define ROWS 6

  #define COLS 7

  int iPointsR[ROWS] = {2, 0, 4, 3, 4, 0}; // 各行黑点数和的情况

  int iPointsC[COLS] = {4, 1, 2, 2, 1, 2, 1}; // 各列黑点数和的情况

  int iCount, iFound;

  int iSumR[ROWS], iSumC[COLS], Grid[ROWS][COLS];

  int Set(int iRowNo) {

  if(iRowNo == ROWS) {

  for(int iColNo=0; iColNo < COLS && iSumC[iColNo]==iPointsC[iColNo]; iColNo++)

  if(iColNo == COLS-1) {

  printf(“\nNo.%d:\n”, ++iCount);

  for(int i=0; i < ROWS; i++)

  for(int j=0; j < COLS; j++)

  printf(“%d%c”, Grid[i][j], (j+1) % COLS ? ‘ ‘ : ‘\n’);

  iFound = 1; // iFound = 1,有解

  }

  } else {

  for(int iColNo=0; iColNo < COLS; iColNo++) {

  if(iPointsR[iRowNo] == 0) {

  Set(iRowNo + 1);

  } else if(Grid[iRowNo][iColNo]==0) {

  Grid[iRowNo][iColNo] = 1;

  iSumR[iRowNo]++; iSumC[iColNo]++; if(iSumR[iRowNo] Set(iRowNo);

  else if(iSumR[iRowNo]==iPointsR[iRowNo] && iRowNo < ROWS)

  Set(iRowNo + 1);

  Grid[iRowNo][iColNo] = 0;

  iSumR[iRowNo]–;

  iSumC[iColNo]–;

  }

  }

  }

  return iFound; // 用于判断是否有解

  }

  int main(int argc, char* argv[]) {

  if(!Set(0))

  printf(“Failure!”);

  }

【笔试算法题:求6*7网格中的黑点分布】相关文章:

迅雷2道算法类笔试真题11-21

基于遗传算法的OD分布03-21

求笔试经验11-19

求DTT的笔试内容11-21

求银行的笔试形式11-21

创新工场2014笔试算法题汇总附答案11-16

笔试面试成绩怎么算法11-12

基于粒子群算法的分布式论文10-27

名企笔试中不同的主观题07-16

搜狐笔试真题编程笔试真题07-23