输入正整数n打印由星号组成的(2*n-1)✖️(2*n-1)的菱形
时间: 2024-12-22 17:12:40 浏览: 6
当然,我们可以使用嵌套循环来创建一个菱形,其中星号的数量按照给定的正整数`n`递增。这里是一个简单的C++程序示例:
```cpp
#include <iostream>
void printDiamond(int n) {
// 上半部分菱形
for (int i = 0; i < n; ++i) {
// 前后两行留空,中间一行有i个 *
std::cout << std::string(2 * n - 1, ' ') << std::string(i, '*') << std::endl;
}
// 下半部分菱形反转
for (int i = n - 1; i >= 0; --i) {
// 前后两行各有i+1个 *
std::cout << std::string(i + 1, '*') << std::string(2 * n - 2, ' ') << std::endl;
}
}
int main() {
int n;
std::cout << "Enter a positive integer n: ";
std::cin >> n;
printDiamond(n);
return 0;
}
```
在这个代码中:
- `printDiamond`函数接收一个参数`n`,表示菱形的高度或宽度(因为它是对称的,所以高度和宽度相同)。
- 上半部分菱形用了一个循环,每次增加一行,每一行的星号数量从0到`i`逐渐递增。
- 下半部分菱形是上半部分的反转,每一行的星号数量从`i`减一到0。
运行这个程序时,输入一个正整数`n`,它会输出对应的菱形。
阅读全文