帕斯卡三角打印问题(有遗留问题)

2016-10-31  本文已影响0人  VikingOldYoung

利用递归打印帕斯卡三角

import java.util.HashMap;
import java.util.Iterator;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Set;

public class PascalTriangle {
    int size;
    Map<Integer, int[]> hashMap;
    
    public PascalTriangle(int size){
        this.size=size;
        hashMap=new HashMap<Integer,int[]>();
        int a[]={1};
        hashMap.put(a.length, a);
        
    }
    
    public int[] triangle(int size){
        
        int x=size;
        int[] a=new int[x];
        if(x==2){
            a[0]=1;
            a[1]=1;
        }else{
            a[0]=1;
            a[x-1]=1;
            for(int i=1;i<a.length-1;i++)
                a[i]=triangle(x-1)[i-1]+triangle(x-1)[i];
        }
        hashMap.put(a.length,a);
        return a;
    }
    
    public void print(Map<Integer, int[]> hashMap){
        Set<Map.Entry<Integer, int[]>> aset=hashMap.entrySet();
        Iterator<Entry<Integer, int[]>> it=aset.iterator();
        while(it.hasNext()){
            Map.Entry<Integer,int[]> entry=it.next();
            int a[]=entry.getValue();
            for(int i=0;i<a.length;i++){
                System.out.print(a[i]+"\t");
            }
            System.out.println();
        }
    }
    
    public static void main(String[] args) {
        PascalTriangle p=new PascalTriangle(9);
        p.triangle(9);
        p.print(p.hashMap);
    }
}

上一篇 下一篇

猜你喜欢

热点阅读