6-1 jmu-python-杨辉三角

6-1 jmu-python-杨辉三角  

 

python对数的范围没有限制 所以可以直接用组合数写  c语言建议还是用二维数组  因为当n足够大时一定会超过unsigned long long的范围   

 

根据输入的n打印n行杨辉三角型。

函数接口定义:

printYanghui(n):#打印n行杨辉三角型

裁判测试程序样例:

/* 请在这里填写答案 */
n = int(input())        
printYanghui(n)

输入格式:

输入n,转化为整数

输出格式:

每个数后面均有一个空格。

输入样例:

5

输出样例:

    1 
   1 1 
  1 2 1 
 1 3 3 1 
1 4 6 4 1 

 

由于没有学过python 里的二维数组(也不知道有没有) 所以用最笨的方法进行打印

思路 : 杨辉三角这个东西其实就是一群组合数
因为每行的第一个元素和最后一个特殊 所以我进行了分开处理
以下是源码

def jiecheng(j,i):   			#计算组合数   i为上面的数 j下面
    m=1
    n=1					#下面的大家都知道   不知道问初中老师 排列组合
    for t in range(j,0,-1):     					
        m*=t  
    for k in range(i-j+1,i+1):
        n*=k  
    return n/m
def printYanghui(n):
        for i in range(n,0,-1):        		  #控制行数
            for j in range(i-1,0,-1):		  # 进行空格的打印
                print(" ", end='')			
            for k in range(0,n-i+1): 		 # 进行元素的计算
                if k==0:			 #第一个数直接打印1 (1后面有个空格)
                    print("1 ", end='')
                    continue
                if k==n-i:			#最后一个数直接打印1 (注意空格)
                    print("1 ", end='')
                    continue
                else:
                    print("%d"%(jiecheng(k,n-i)), end=' ')   #其他数进行 组合数计算  定义一个“jiecheng()”函数
            print()
                

以下为测试结果(***题目没有说格式化输出***):

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值