Melhor maneira de refatorar esse código C? CS50 - mario.c (mais)

votos
-3

Então Im fazer o curso CS50 e resolver o mario.c mais de pset 1

Na verdade, eu resolvido com 3 loops, mas eu queria refatorar-lo com apenas 2 voltas e eu vim com esse código que dá a seguinte solução para altura: 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);
    }
}

Eu gostaria de saber se vocês podem me mostrar uma solução mais elegante desde que eu acho que isso é muito ... repetitivo.

Além disso, é possível usar caso interruptor em vez de tantos else if? Tentou fazê-lo, mas o código não demorou booleans para j :(

Desde já, obrigado! :)

Publicado 02/09/2018 em 05:38
fonte usuário
Em outras línguas...                            


1 respostas

votos
1

Se você conhece um limite superior para a altura, você pode fazê-lo em um único laço.

Gostar:

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;
}

Nota: Se você não sabe um limite superior para a altura, você ainda pode usar essa abordagem, mas, em seguida, sdeve ser dinâmico alocado.

Respondeu 02/09/2018 em 06:23
fonte usuário

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