基因牛

  1. /* 
  2.  * 基因牛 
  3.     张教授采用基因干预技术成功培养出一头母牛,三年后,这头母牛每年会生出1头母牛,  
  4.     生出来的母牛三年后,又可以每年生出一头母牛。如此循环下去,请问张教授n年后有多少头母牛? 
  5.     以下程序模拟了这个过程,请填写缺失的代码。 
  6.  */  
  7. import java.util.ArrayList;  
  8. import java.util.List;  
  9. class Cow{  
  10.     private int age;  
  11.     public Cow afterYear(){  
  12.         age++;  
  13.         return age > 2 ? new Cow() : null;   // 填空  
  14.     }  
  15.     public static void showTotalCowNum(int n){  
  16.         List<Cow> list = new ArrayList<Cow>();  
  17.         list.add(new Cow());  
  18.   
  19.         for (int i = 0; i < n; i++)  {  
  20.             int cowCount = list.size();  
  21.             for (int j = 0; j < cowCount; j++){  
  22.                 Cow cow = list.get(j).afterYear();  
  23.                 if (cow != null){  
  24.                     cow.afterYear();    // 填空  
  25.                     list.add(cow);  
  26.                 }  
  27.             }  
  28.         }  
  29.         System.out.println(n + "年后,共有:" + list.size());       
  30.     }  
  31. }  
  32. class Demo05{  
  33.     public static void main(String[] args){  
  34.         Cow.showTotalCowNum(13);  
  35.     }  
  36. }  
运行结果:
[plain]  view plain copy
  1. 13年后,共有:233  

你可能感兴趣的:(线性表)