本文教你使用二维字符串数组构建国家与首都对照表,并通过动态计算列宽、添加空格填充,实现美观的左对齐表格格式输出。
在 Java 中,用二维数组(如 String[][])模拟表格结构是一种常见且实用的入门实践。但要让输出真正呈现为“表格”——即各列文字垂直对齐——关键不在于存储数据,而在于格式化输出。原始代码中嵌套循环逐个打印元素,导致每行拆成两行输出(国家一行、首都一行),完全破坏了表格结构;更严重的是,缺乏列宽控制,文字自然左靠拢后无法对齐。
解决思路分为三步:分离关注点、计算最大列宽、按需补空格。以下是一个清晰、可维护的专业写法:
public class Arrays39 {
public static void main(String[] args) {
String[][] countries = {
{"Mexico", "DF"},
{"Guatemala", "Guatemala City"},
{"El Salvador", "El Salvador"},
{"Russia", "Moscow"}
};
int maxCountryLength = maxPadding(countries);
generateTable(countries, maxCountryLength);
}
// 主输出方法:打印表头 + 每行数据(国家 + 空格填充 + 首都)
public static void generateTable(String[][] data, int padding) {
// 表头:Country 后补足 padding 空格,再接 Capital
System.out.printf("Country%sCapital%n", " ".repeat(Math.max(0, padding - "Country".length() + 1)));
for (String[] row : data) {
String country = row[0];
String capital = row[1];
// 计算当前国家名需补充的空格数(使所有国家列右边界对齐)
int spacesNeeded = Math.max(0, padding - country.length() + 1);
System.out.printf("%s%s%s%n", country, " ".repeat(spacesNeeded), capital);
}
}
// 辅助方法:找出第一列(国家名)中最长字符串的长度
private static int maxPadding(String[][] data) {
int max = 0;
for (String[] row : data) {
if (row.length > 0 && row[0] != null) {
max = Math.max(max, row[0].length());
}
}
return max;
}
}✅ 关键改进说明:
⚠️ 注意事项:
掌握这种“数据存储 + 格式化渲染”分离的思想,是你从数组练习迈向真实 Java 应用开发的重要一步。