运用递归搞定单次循环打印菱形的问题

 
/**
打印效果如下
   * 
  * *
 * * *
  * *
   *
 *  根据回溯想到的旧问题的新算法
 * @author LeLe
 *
 */
public class PrintTriangle {
   
    /**
     * 第一次写出的
     * @param times
     * @param ask
     */
    void printA(int times,boolean ask){
        for (int i = 5; i > 0; i--) {
            if(i<=5-times+1)
            System.out.print(" *");
            else
            System.out.print(" ");
        }
        System.out.println("");
        if(times >1&&ask)
            this.printA(times-1,true);
        if(ask)
            this.printA(times+1,false);
    }
    /**
     * 根据第一次写出进行优化的
     * @param times
     * @param ask
     */
    void printB(int times,boolean ask){
        for (int i = 5; i > 0; i--) {
            if(i<=5-times+1)
            System.out.print(" *");
            else
            System.out.print(" ");
            if(i == 1)
                System.out.println("");
            if(i==1&&times>1&&ask)
                this.printB(times -1,true);
            if(i==1&&ask)
                this.printB(times+1,false);
        }
    }
   
    public static void main(String[] args){
        PrintTriangle p = new PrintTriangle();
        long a = System.currentTimeMillis();
        p.printB(5,true);
        long b = System.currentTimeMillis();
        System.out.println(" 执行时间为 "+(b-a)+"毫秒");
    }
 
} 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值