三种语言输出杨辉三角形
首先聊聊什么是杨辉三角形,下图是杨辉三角的排列方式:
有如下规律:
1.左右两边都是1
2.有n行那么第n行就有n个数
3.每行除了左右两边的数之外,第n行第l列的数字是第n-1行的l-1与第n-1行的l数之和
好了,了解了它的规律之后,咋们直接上代码
- java语言实现
/**
* @author Rookie
* @version 11.0
* 自信来源于实力,实力来源于勤奋。
*/
public static void main(String[] args) {
int[] arr[] = new int[10][];
put(arr);
out(arr);
}
public static void put(int[] arr[]) {
for (int i = 0; i < arr.length; i++) {
//初始化每一行
arr[i] = new int[i + 1];
//进行赋值
for (int j = 0; j < arr[i].length; j++) {
if (j == 0 || j == arr[i].length - 1) {
arr[i][j] = 1;
} else {
arr[i][j] = arr[i - 1][j] + arr[i - 1][j - 1];
}
}
}
}
public static void out(int[] arr[]) {
//输出杨辉三角形
for (int i = 0; i < arr.length; i++) {
for (int j = 0; j < arr[i].length; j++) {
System.out.print(arr[i][j] + " ");
}
System.out.println();
}
}
- python语言实现
# @BY :Rookie
# @File : Yang_Hui.py
# -*- coding: utf-8 -*-
# @Time : 2021/11/23 10:52
# @Motto :自信来源于实力,实力来源于勤奋
def Yang_hui(x):
list1 = []
for n in range(x): # 行数
row = [1]
list1.append(row)
if n == 0:
print(row)
continue
for m in range(1, n): # 每行个数
row.append(list1[n - 1][m - 1] + list1[n - 1][m])
row.append(1)
print(row)
Yang_hui(10)
- c语言实现
#include <stdio.h>
int main()
{
int a[10][10]={};
int i,j;
for(i=0;i<10;i++){
for(j=0;j<=i;j++){
a[i][j] = 0;
if(j==0 || i==j){
a[i][j] = 1;
}else{
a[i][j] = a[i-1][j-1]+a[i-1][j];
}
printf("%2d ",a[i][j]);
}
printf("\n");
}
return 0;
}
以上就是通过c、java、python实现杨辉三角形,写得不是很好,请给位大佬给我指点迷津,下次改进,谢谢给位大佬。