因此,我上了CS50课程,并从pset 1中解决了mario.c
我实际上用3个for循环解决了它,但是我只想用2个循环来重构它,我想出了这段代码,它为“ height: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:(
提前谢谢! :)
答案 0 :(得分: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
必须是动态分配的。