Java算法之经典问题篇(三)

本文介绍了一种使用Java编程语言绘制巴斯卡三角形的方法。通过递归组合计算公式来生成每一项值,并利用Swing图形库进行可视化展示。
 
巴斯卡三角形(Pascal)
问题说明:
        巴斯卡(Pascal)三角形基本上就是在解nCr 因为三角形上的每一个数字各对应一个nCr 其中nrow,而rcolnmu。

算法代码(Java):

import java.awt.*
import javax.swing.*

public class Pascal extends JFrame 
    
public Pascal() 
        setBackground(Color.white); 
        setTitle(
"巴斯卡三角形"); 
        setSize(
520350); 
        setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); 
        show(); 
    }
 

    
private long combi(int n, int r)
        
int i; 
        
long p = 1

        
for(i = 1; i <= r; i++
            p 
= p * (n-i+1/ i; 
  
        
return p; 
    }
 

    
public void paint(Graphics g) 
        
final int N = 12
        
int n, r, t; 

        
for(n = 0; n <= N; n++
            
for(r = 0; r <= n; r++
                g.drawString(
" " + combi(n, r), 
                    (N
-n)*20 + r * 40, n * 20 + 50); 
        }
 
    }
 

    
public static void main(String args[]) 
        Pascal frm 
= new Pascal(); 
    }
 
}

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值