我有一个相当容易的问题。我只需要逻辑或代码。我将非常感激。
假设我有一个像下面这样的二维数组:
[
['Main Menu', 'User Menu', 'Account', 'Enquiries', 'Query by Name'],
['Main Menu', 'User Menu', 'Account', 'Enquiries', 'Query by ID'],
['Main Menu', 'User Menu', 'Account', 'Create', 'Create Type'],
['Main Menu', 'User Menu', 'Account', 'Create', 'Create Account'],
['Main Menu', 'User Menu', 'Client', 'Enquiries', 'Query by Client Name'],
['Main Menu', 'User Menu', 'Client', 'Create', 'Create Client']
]
我希望程序显示如下
Main Menu
-User Menu
--Account
---Enquiries
----Query by Name
----Query by ID
Main Menu
-User Menu
--Account
---Create
----Create Type
----Create Account
Main Menu
-User Menu
--Client
---Enquiries
----Query by Client Name
Main Menu
-User Menu
--Client
---Create
----Create Client
顺便说一句,如果有另一种存储数据的方法,而不是使用2D数组,这会使上面的显示更容易编码,你可以提一下。
答案 0 :(得分:3)
您可以创建一个类Menu
,如下所示:
class Menu{
private String name; // menu name
private List<Menu> subMenu; // list of sub menus
// getter and setter
// recursive method for displaying menus in desired format
public String displayString(String prefix) {
StringBuilder builder = new StringBuilder();
if(subMenu != null){
for (Menu menu : subMenu) {
builder.append(menu.displayString(prefix + " "));
}
}
return prefix + name + "\n" + builder.toString();
}
}
使用此结构,您可以轻松存储数据并以您希望的方式进行打印。
答案 1 :(得分:0)
如果你想在你的问题中使用锯齿状阵列设计,我个人没有问题(许多方法可以让所有猫皮肤化),只需使用内部循环方法:
for (String[] menuList : menuArray) {
for (int i = 0; i < menuList.length; i++) {
//print out values
}
}
此外,虽然您可能只是为了简洁而编写代码,但请记住您的2D数组语法不会编译。