递归填充形状的程序

时间:2013-08-05 09:13:29

标签: c arrays multidimensional-array fill

大约两周前,我发布了一个类似的问题,我解决了我的问题。但是,经过一些修改后,我的程序无法正常工作。说明用于获取形状的周长,由用户以星号()绘制,然后用星号()填充形状。

有两个问题:

1) The program fails to print the full input shape (at end of getArray function)
2) The program does not fill an input shape problem for row > 9 or column > 9.

我想知道为什么会出现这些问题,以及如何解决这些问题。

这是程序代码(抱歉长度):

#include <stdio.h>
#include "simpio.h"
#include "genlib.h"

void getArray(char array[][20]);
int getRow(void);
int getColumn(void);
void fill(char array[][20], int row, int column);
void dispArray(char array[][20]);
void dispMsg(void);

main()
{
      char array[20][20];
      int row, column;

      dispMsg();
      getArray(array);
      printf("\nPlease enter an interior point from which the program starts filling.\n");
      row=getRow();
      column=getColumn();
      fill(array, row, column);
      dispArray(array);

      getchar();
}

void dispMsg(void)
{
      printf("This program will ask you to input the outline of a shape, and it will fill the shape up.\n");
}

void fill(char array[][20], int row, int column)
{
     if(array[row][column] != ' '|| row>20 || row<0 || column>20 || column<0)
     { 
     }
     else
     {
         array[row][column] = '*';
         fill(array, row, column+1);
         fill(array, row+1, column);
         fill(array, row, column-1);
         fill(array, row-1, column);
     }
}

void dispArray(char array[][20])
{
     int i, j;

     for(i = 0; i < 20; i++)
     {
              printf("\n");
              for(j = 0; j < 20; j++)
              {
                          printf("%c", array[i][j]);
              }
     }
}

int getRow(void)
{
      int row;

      printf("\nEnter the row of the point: \n");
      row = GetInteger();
      return(row);   
}

int getColumn(void)
{
      int column;

      printf("Enter the column of the point: ");
      column = GetInteger();
      return(column);   
}

 void getArray(char array[][20])
 {
    int i, j, row = 0, column = 0, num;
    char input;

    printf("To input the perimeter of your shape please use asterisks(*), and the <enter>   key to start a new line.\nEnd the input with the '!' signal\n\n");
    for(i=0;i<20;i++)
    {
               for(j=0;j<20;j++)
               {
                     array[i][j] = ' ';
               }
    }
    i=0;
    j=0;
    while(true)
    {
              input=getchar();
              if(input=='\n')
              {
                     i++;
                     j=0;
                     row++;
                     column = num;
                     num = 0;
              }
              else if(input=='!')
              {
                     if(array[i-1][j] == '*')      row--;      
                     break;
              }
              else
              {
                     array[i][j] = input;
                     j++;
                     num++;
              }
      }
      printf("Your input shape is: \n");

      for(i=0;i <= row;i++)
      {
               printf("\n");
               for(j=0;j <= column;j++)
               {
                            printf("%c", array[i][j]);
               }
      }
 }

例如:

If the user enters:

**************
*            *****
*                *
*                *
*                *
******************

The output will be:

**************
******************
******************
******************
******************
******************

然而,对于我的计划:

When the input is re-printed, this comes out:

****************  *
*              *****           *
*                  *           *
*                  *           *
*                 ***

And when the fill is printed:

******************
*             ****************
*             ****************
*             ****************
******************
******************

非常感谢帮助,谢谢:)

1 个答案:

答案 0 :(得分:2)

问题是你对列数的计算。

您必须记住两件事:

第一个是整数除法截断结果。例如,根据您问题中的输入,column44row6,结果为44 / 6 7.3333333...。但是,由于它是整数运算,因此您将获得7

第二件事是你不能通过将星号数除以行数来获得列数。相反,您需要一个单独的计数器来计算当前行的列数。如果它大于当前column值,则设置新的列数。