输出数字金字塔(数字1-9)

#include <stdio.h>
//输出数字金字塔(数字1-9)
int main()
{
	int n,i,j,k;
	scanf("%d",&n);
	for (i=1;i<=n;i++)
	{
		for (j=1;j<=n-i;j++) printf(" ");
		for (k=1;k<=i;k++)
		{
			if (k==i)
			{
				printf("%d",i);
			}else{
				printf("%d ",i);
			}
		}
		printf("\n");  
	}
	return 0;
} 

### 数字金字塔的数组实现 使用数组实现数字金字塔是一种常见的编程任务,可以通过二维数组来存储每一层的数字,并通过循环生成和输出金字塔结构。以下是基于引用内容和专业知识的详细实现方法。 #### 1. 数组实现的基本思路 - 使用一个二维数组 `pyramid` 来存储金字塔的每一层。 - 每一层的数字数量与该层的行号一致。例如,第 `n` 行包含 `n` 个数字- 通过嵌套循环生成金字塔的每一层,并将其存储到数组中。 - 最后遍历数组并格式化输出金字塔。 #### 2. 示例代码实现 (Java) 以下是一个使用 Java 实现的数字金字塔示例: ```java import java.util.Scanner; public class NumberPyramid { public static void main(String[] args) { Scanner scanner = new Scanner(System.in); System.out.print("请输入金字塔的层数(1-9):"); int layers = scanner.nextInt(); // 验证输入是否在范围内 if (layers < 1 || layers > 9) { System.out.println("输入的层数必须在19之间!"); return; } // 创建二维数组存储金字塔 int[][] pyramid = new int[layers][]; // 构建金字塔 for (int i = 0; i < layers; i++) { pyramid[i] = new int[i + 1]; for (int j = 0; j <= i; j++) { pyramid[i][j] = j + 1; // 填充数字 } } // 打印金字塔 for (int i = 0; i < layers; i++) { // 输出空格以对齐金字塔 for (int k = 0; k < layers - i - 1; k++) { System.out.print(" "); } for (int j = 0; j <= i; j++) { System.out.print(pyramid[i][j] + " "); } System.out.println(); } } } ``` #### 3. 示例代码实现 (C++) 以下是一个使用 C++ 实现的数字金字塔示例: ```cpp #include <iostream> #include <vector> using namespace std; int main() { int layers; cout << "请输入金字塔的层数(1-9):"; cin >> layers; // 验证输入是否在范围内 if (layers < 1 || layers > 9) { cout << "输入的层数必须在19之间!" << endl; return 0; } // 创建二维向量存储金字塔 vector<vector<int>> pyramid(layers); // 构建金字塔 for (int i = 0; i < layers; i++) { pyramid[i].resize(i + 1); for (int j = 0; j <= i; j++) { pyramid[i][j] = j + 1; // 填充数字 } } // 打印金字塔 for (int i = 0; i < layers; i++) { // 输出空格以对齐金字塔 for (int k = 0; k < layers - i - 1; k++) { cout << " "; } for (int j = 0; j <= i; j++) { cout << pyramid[i][j] << " "; } cout << endl; } return 0; } ``` #### 4. 示例代码实现 (Python) 以下是一个使用 Python 实现的数字金字塔示例: ```python def print_number_pyramid(layers): if layers < 1 or layers > 9: print("输入的层数必须在19之间!") return # 创建二维列表存储金字塔 pyramid = [[j + 1 for j in range(i + 1)] for i in range(layers)] # 打印金字塔 for i in range(layers): # 输出空格以对齐金字塔 print(&#39; &#39; * (layers - i - 1), end=&#39;&#39;) for j in range(len(pyramid[i])): print(pyramid[i][j], end=&#39; &#39;) print() # 输入层数 layers = int(input("请输入金字塔的层数(1-9):")) print_number_pyramid(layers) ``` #### 5. 关键点解析 - **数组存储**:二维数组或向量用于存储金字塔的每一层,便于后续操作和输出[^1]。 - **输入验证**:确保用户输入的层数在合理范围内(如 19),避免异常情况。 - **格式化输出**:通过调整空格数量实现金字塔的对齐效果[^2]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值