酷代码 AI
菜单
服务商

编程实现星耀结晶金字塔形状输出

要解决这个问题,我们需要在给定的代码框架内完成两个嵌套的`for`循环,一个用于输出空格以实现等腰三角形的形状,另一个用于输出星号`*`。 ### 思路分析 - 外层循环控制行数,从 1 到 `n` 进行迭代,代表金字塔的每一层。 - 第一个内层循环用于输出空格,在每一行中,空格的数量等于`n - i`,其中`i`是当前行数。 - 第二个内层循环用于输出星号,每一行星号的数量等于`2 * i - 1`。 ### 完整代码 ```cpp #include <iostream> using namespace std; int main() { int n; cin >> n; // 外层循环控制行数 for (int i = 1; i <= n; i++) { // 第一个内层循环输出空格 for (int j = 1; j <= n - i; j++) { cout << " "; } // 第二个内层循环输出星号 for (int k = 1; k <= 2 * i - 1; k++) { cout << "*"; } // 每行结束后换行 cout << endl; } return 0; } ``` ### 代码解释 1. **输入部分**:使用`cin`读取用户输入的整数`n`,代表金字塔的层数。 2. **外层循环**:`for (int i = 1; i <= n; i++)`控制行数,从第 1 行到第`n`行。 3. **第一个内层循环**:`for (int j = 1; j <= n - i; j++)`输出空格,空格数量随着行数的增加而减少。 4. **第二个内层循环**:`for (int k = 1; k <= 2 * i - 1; k++)`输出星号,星号数量随着行数的增加而增加。 5. **换行**:每行输出结束后,使用`cout << endl;`进行换行。 ### 复杂度分析 - **时间复杂度**:$O(n^2)$,因为有两层嵌套的循环。 - **空间复杂度**:$O(1)$,只使用了常数级的额外空间。 ######[AI问答 | 546点数解答 | 2026-02-26 19:57:45]

相关提问
发财导航,免费问AI
实用工具查看更多
Linux在线手册 [开发类]
Jquery在线手册 [开发类]
今日油价 [生活类]
图片互转base64 [开发类]
时间转换器 [开发类]