微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

如何在Java中输出缩进字符串?

如何解决如何在Java中输出缩进字符串?

我正在做河内塔楼,我想输出所有移动(2 ^ n-1)并增加领先空间。 例如

Moving top disk from....
    Moving top disk from....
        Moving top disk from....
            Moving top disk from....

...等等。

我试图创建一个单独的“空格”方法,但不确定如何将其实现到程序中

这是我代码的一部分。

public static void towersOfHanoi(int disk,int source,int dest){
        int temp;
        if (disk == 1) {
            movedisk(source,dest);
        }
        else {
            temp = 6 - source - dest;
            towersOfHanoi(disk-1,source,temp);
            movedisk(source,dest);
            towersOfHanoi(disk-1,temp,dest);
        }
    }
    
    private static void movedisk(int source,int dest) {
        System.out.println("Moving top disk from " + source + " to " + dest);
    }

解决方法

您可以通过Apache Commons Framework.

import org.apache.commons.lang3.StringUtils

然后使用:

StringUtils.leftPad("123456",tab_length * 2) 
//or however you want to format the left space

这是最方便的方法,否则,您可以使用StringBuilder或类似工具编写自定义的leftPad方法。

,

我已经使用字符串生成器来实现缩进。缩进数量由静态变量为“缩进”类定义,每次调用moveDisk方法时都使用for循环。

public class Test {

    static Integer indents = -2;
    static String indent = "   ";
    public static void towersOfHanoi(int disk,int source,int dest){
        int temp;
        if (disk == 1) {
            moveDisk(source,dest);
        }
        else {
            temp = 6 - source - dest;
            towersOfHanoi(disk-1,source,temp);
            moveDisk(source,dest);
            towersOfHanoi(disk-1,temp,dest);
        }
    }

    private static void moveDisk(int source,int dest) {

        indents = indents + 1;

        StringBuilder sb = new StringBuilder();

        for(int i = 0; i<=indents; i++){
            sb.append(indent);
        }
        sb.append("Moving top disk from ");
        sb.append(source);
        sb.append( " to ");
        sb.append( dest);

        System.out.println(sb.toString());
    }

    public static void main(String[] args) {

        moveDisk(10,10);
        moveDisk(1,10);
        moveDisk(20,10);

    }
}

结果:

Moving top disk from 10 to 10
   Moving top disk from 1 to 10
      Moving top disk from 20 to 10

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。