印刷半金字塔

Printing half pyramid

本文关键字:金字塔      更新时间:2023-10-16

如果输入为 6,我希望金字塔看起来像这样

     0
    12
   345
  6789
 01234
567890

这是我的代码

void HalfPyramid(int num)
{
    for (int a=0; a<num; a++)
    {
        for (int b=0; b<num-a; b++)
        {
        cout << " ";
        }
        for (int c=0; c<a; c++)
        {
            cout << a;
        }
        cout << endl;
    }
}

我得到了

     1
    22
   333
  4444
 55555

不确定如何显示数字在整个过程中增加,我尝试输出aa+1

你需要另一个变量。 该变量需要从 0 开始,并在每次打印时递增。 然后,由于您需要在打印 9 后回绕到 0,我们将使用模运算符将输出限制在 [0, 9] 的范围。 用你得到的一切

void HalfPyramid(int num)
{
    int output = 0;
    for (int a=1; a<num+1; a++)
    {
        for (int b=0; b<num-a; b++)
        {
            cout << " ";
        }
        for (int c=0; c<a; c++)
        {
            cout << output++ % 10;
        }
        cout << endl;
    }
}
void HalfPyramid(int num)
{
    int cur = 0;
        for (int a=0; a<num; a++)
        {
        for (int b = 1; b < num - a ; b++)
        {
            cout << " ";
        }
        for (int c=0; c < a + 1; c++)
        {
            cout << cur;
            cur = (cur+1)%10;
        }
        cout << endl;
    }
}

其他答案已经提供了HalfPyramid的工作版本。希望这个答案能让你对逻辑和功能的看法有所不同。我喜欢创建小函数来捕捉我想要做的本质,而不是使用语言来做这件事。

bool isSpace(int num, int a, int b) 
{
   return ((a + b) < (num - 1));
}
int getNextDigit(int in)
{
   return (in+1)%10;
}
void HalfPyramid(int num)
{
   int digit = 0;
   for (int a = 0; a < num; ++a)
   {
      for (int b = 0; b < num; ++b)
      {
         if ( isSpace(num, a, b) )
         {
            cout << " ";
         }
         else
         {
            cout << digit;
            digit = getNextDigit(digit);
         }
      }
      cout << endl;
   }
}