Лучший способ реорганизовать это C-код? CS50 - mario.c (больше)

голоса
-3

Так Im принимая CS50 курс и решения mario.c больше от PSET 1

Я на самом деле решить ее с 3 на петлях, но я хотел, чтобы реорганизовать его только с 2 петлями и я придумал этот код, который дает следующее решение «высота: 5»

Result:
    #  #
   ##  ##
  ###  ###
 ####  ####
#####  #####

#include <stdio.h>

int main(void)
{
   
    int side = 5;
    int max = side + 2;

    for (int i = 1 ; i <= side ; i++)
    {
      int j = 1;
      while(j != max+1)
      {
        if(j <= side-i)
        {
        printf( );
        j++;
        }
        else if(j > side-i && j < side+1)
        {
        printf(#);
        j++;
        }
        else if(j == side+1)
        {
        printf(  );
        j++;
        } 
        else 
        {
        printf(#);
        j++;
        }
      }
    max++;
    printf(\n);
    }
}

Я бы хотел знать, если вы, ребята, можете показать мне более элегантное решение, так как я думаю, что это слишком ... повторы.

Кроме того, можно использовать переключатель случай вместо так много еще, если? Пытался сделать это, но код не брал булевы для J :(

Заранее спасибо! :)

Задан 02/09/2018 в 05:38
источник пользователем
На других языках...                            


1 ответов

голоса
1

Если вы знаете, верхний предел высоты, вы можете сделать это в одном цикле.

Подобно:

int main(void) {
    char s[] = "#############################################";
    char f[32];

    int n = 5;  // height

    sprintf(f, "%%%ds  %%s", n);   // Create a format string like "%5s  %s"
    char* p = s + strlen(s) - 1;   // Let p point to the last char in s

    for(int i=0; i<n; i++)         // Loop n times
    {
        printf(f, p, p);
        printf("\n");
        p--;                       // Increase the number of # that p points to
    }
    return 0;
}

Примечание: Если вы не знаете , верхний предел высоты, вы можете использовать этот подход , но тогда sдолжны быть динамичными выделено.

Ответил 02/09/2018 в 06:23
источник пользователем

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more