利用递归打印帕斯卡三角
- 自己思路也有点乱了,核心思想是递归的往上去实现上一层的数组。一直往上到第二层就可以算第三层的了,再依次往下去求。每一层算完都把这一层的结果保存到map里面。之所以用map也是没办法,因为他会重复把已经算过的也给加进去,感觉是两次就可以了但是怎么也加不完。只好用map。数组的长度作为键。就不会重复加相同长度的数组了,加了也是覆盖了。。没办法,留作以后再来看。!!!
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);
}
}