)柄探三角形 编程打印具有如下形式的杨辉三角形(它的特点是左右两边全是1,从第二行起,中间的每一个数是上一行里相邻两个数之和》,其中输出数据的行数口人键盘输入,并且n<=10。 程序运行结果示例1: input a n=10): 1 1 1 1 3 N 1464 1 程序ー行結果示例2: anput n (n-10) 111 1 141 5 10 4 10 1 5 51500 15 1 6 1 输入格式: "Ma* 輸出格式: 輸入提示信息: minput n (n=10) :10" 输出数据格式: “%4d”数据换行:“\n”
时间: 2024-02-24 17:55:49 浏览: 163
以下是Python3代码实现:
```python
n = int(input("input a n(n<=10): "))
if n < 1 or n > 10:
print("Invalid input!")
else:
# 初始化第一行
row = [1]
print("%4d" % 1)
# 逐行生成并输出杨辉三角
for i in range(2, n+1):
# 生成当前行
row = [1] + [row[j] + row[j+1] for j in range(i-2)] + [1]
# 输出当前行
for num in row:
print("%4d" % num, end="")
print()
```
输出结果示例:
```
input a n(n<=10): 10
1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
1 5 10 10 5 1
1 6 15 20 15 6 1
1 7 21 35 35 21 7 1
1 8 28 56 70 56 28 8 1
1 9 36 84 126 126 84 36 9 1
```
相关问题
由c语言编程打印具有如下形式的杨辉三角形(它的特点是左右两边全是工,从第二行起,中间的每一个数是上一行里相 邻两个数之和》,其中输出数据的行数口从键盘输入,并且n=108
好的,以下是C语言代码实现:
```c
#include <stdio.h>
int main() {
int n, i, j, k;
printf("请输入行数:");
scanf("%d", &n);
int a[n][n]; // 二维数组存储杨辉三角形
// 初始化
for (i = 0; i < n; i++) {
for (j = 0; j < n; j++) {
a[i][j] = 0;
}
}
// 赋值
a[0][n/2] = 1; // 第一行只有中间一个数是1
for (i = 1; i < n; i++) {
for (j = 1; j < n-1; j++) {
a[i][j] = a[i-1][j-1] + a[i-1][j+1]; // 根据公式计算
}
}
// 输出
for (i = 0; i < n; i++) {
for (j = 0; j < n; j++) {
if (a[i][j] != 0) { // 只输出不为0的数
printf("%d ", a[i][j]);
}
}
printf("\n");
}
return 0;
}
```
这个杨辉三角形是以中间列为基准,所以我把第一行的1放在了中间列。输出结果如下:
```
请输入行数:10
1
1 1 1
1 2 2 2 1
1 3 4 4 4 3 1
1 4 7 8 8 7 4 1
1 5 11 15 16 15 11 5 1
1 6 16 26 31 31 26 16 6 1
1 7 22 42 57 63 57 42 22 7 1
1 8 29 64 99 120 120 99 64 29 8 1
```
由c语言实现编程打印具有如下形式的杨辉三角形(它的特点是左右两边全是工,从第二行起,中间的每一个数是上一行里相 邻两个数之和》,其中输出数据的行数口从键盘输入,并且n<=10
好的,以下是C语言代码实现:
```c
#include <stdio.h>
int main() {
int n, i, j, k;
printf("请输入行数:");
scanf("%d", &n);
int a[n][n]; // 二维数组存储杨辉三角形
// 初始化
for (i = 0; i < n; i++) {
for (j = 0; j < n; j++) {
a[i][j] = 0;
}
}
// 赋值
a[0][0] = 1; // 第一行只有一个1
for (i = 1; i < n; i++) {
a[i][0] = 1; // 每行第一个数都是1
a[i][i] = 1; // 每行最后一个数都是1
for (j = 1; j < i; j++) {
a[i][j] = a[i-1][j-1] + a[i-1][j]; // 根据公式计算
}
}
// 输出
for (i = 0; i < n; i++) {
for (j = 0; j < n; j++) {
if (a[i][j] != 0) { // 只输出不为0的数
printf("%d ", a[i][j]);
}
}
printf("\n");
}
return 0;
}
```
这个杨辉三角形是以左对齐的方式输出的,所以每行的第一个数都在最左边,最后一个数都在最右边。输出结果如下:
```
请输入行数:5
1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
```
阅读全文