2

我对编程比较陌生。我现在正在尝试制作一个程序,并且我正在尝试弄清楚我该如何做某事。我希望你们能帮助我,因为我只是不知道如何做到这一点......

所以,首先,我做了一个数组并用东西填充它:

String[] pizza = new String[10];
    pizza[0] = "1- Cheese";
    pizza[1] = "2- Wedge";
    pizza[2] = "3- Bacon";
    pizza[3] = "4- Hawaiian";
    pizza[4] = "5- Vegetarian";
    pizza[5] = "6- Pepperoni";
    pizza[6] = "7- Ham";
    pizza[7] = "8- Apple";
    pizza[8] = "9- Grape";
    pizza[9] = "10- Italian";

我想这样做,以便我有一个 IF 语句(在一段时间内)。我只是把代码放在这里,然后解释。

int pizzaCounter = 0;

        while(pizzaCounter < 5)
        {

            Scanner pizzaPick = new Scanner(System.in);
            int Pizzas = pizzaPick.nextInt();

            if (Pizzas == 1)
            {
                *Store "1- Cheese" (From pizza[0]) into a variable*

                pizzaCounter++;
            }
            if (Pizzas == 2)
            {
                *Store "2- Wedge" (From pizza[0]) into a variable*

                pizzaCounter++;
            }
            if (Pizzas == 3) etc...

        }

现在在“在此处插入一些东西”位,我想尝试使其将数组(披萨)中的文本存储到一些我可以稍后打印出来的变量中......例如,如果用户输入'1 ' 然后它需要:“1-Cheese”并将其存储在一个变量中,我可以稍后打印出来......

另外,我想让它干净,这样就没有 10 个 IF 语句提示每个变量的事情......?

我不知道这是否可能,但非常感谢任何帮助!:D

我希望我在这里问的问题是可以理解的......

如果可能的话,请您解释一下您在每个步骤中所做的事情,以便我能够真正理解正在发生的事情,并且以后可能会使用相同的代码,而不是仅仅复制并粘贴代码?我是个菜鸟,所以我认为我学的越多,以后可以使用的越多……非常感谢!:D

4

4 回答 4

4

您可以将整个系列if语句替换为以下内容:

string saveName = "";
if ((Pizzas >= 0) && (Pizzas <= 9)) {
    saveName = pizza[Pizzas];           // This is "insert something here".
    pizzaCounter++;
}

// Here, saveName has the pizza name.

对于允许您最多订购五个比萨饼、保存批次并在最后打印出来的完整程序,请参见下文:

import java.util.Scanner;

public class testprog {
    public static void main (String args[]) {
        String[] pizzaList = {" 0 - End of order",
            " 1 - Cheese", " 2 - Wedge", " 3 - Bacon", " 4 - Hawaiian",
            " 5 - Vegetarian", " 6 - Pepperoni", " 7 - Ham", " 8 - Apple",
            " 9 - Grape", "10 - Italian"};

        int[] orderList = new int[5];  // Ordered pizzas
        int pizzaCount = 0;            //    and count.

        Scanner pizzaPick = new Scanner(System.in);
        while (pizzaCount < 5) {
            // Output the menu.

            System.out.println ("Choose a pizza:");
            for (int i = 0; i < pizzaList.length; i++)
                System.out.println ("   " + pizzaList[i]);

            // Get input, check, and add pizza.

            int thisPizza = pizzaPick.nextInt();
            if (thisPizza == 0) break;

            if ((thisPizza > 0) && (thisPizza < pizzaList.length))
                orderList[pizzaCount++] = thisPizza;

            if ((thisPizza < 0) || (thisPizza >= pizzaList.length))
                System.out.println ("Invalid input of " + thisPizza);
        }

        // Output all pizzas.

        for (int i = 0; i < pizzaCount; i++)
            System.out.println ("Ordered: " + pizzaList[orderList[i]]);
    }
}
于 2012-05-07T05:58:43.490 回答
0

您可以在此处执行一些操作来优化代码。首先,放弃 while 循环以支持 for 循环,如下所示:

for (int i = 0; i < 5; i++) {
    // Will loop 5 times
}

其次,您可以将 if 语句替换为 switch 语句,如下所示:

switch (pizzaPick.nextInt()) {
    case 0:
        // Do something
        break;
    case 1:
        // Do something else
        break;
    case 2:
        // Etc.
        break
}

但是,我们实际上可以进一步优化它,这将完全不需要 switch 语句。不过,首先,我们需要一个变量来存储挑选的比萨饼。我们可以使用另一个数组,它有 5 个元素长。像这样创建它:

String[] pickedPizzas = new String[5];

现在我们可以用它来存储挑选的比萨饼。然后我们可以在每个循环中执行此操作以保存挑选的比萨饼:

pickedPizzas[i] = pizza[pizzaPick.nextInt()];

如您所见,我们甚至不需要使用 ifs 或 switch,因为我们可以使用赋值。我们可以通过对数组使用括号语法来继续优化。您可以像这样初始化数组:

String[] strArray = {"one", "two", "three", ...};

这节省了空间并且更简单。最重要的是,将扫描仪的声明移到循环之外。由于循环的范围,将其放置在循环内将导致每次循环执行时重新创建和销毁它。将它放在循环之外将解决这个问题。

以下是最终代码的样子:

// Hold all the pizza names
String[] pizzas = {
    "1- Cheese",
    "2- Wedge",
    "3- Bacon",
    "4- Hawaiian",
    "5- Vegetarian",
    "6- Pepperoni",
    "7- Ham",
    "8- Apple",
    "9- Grape",
    "10- Italian"
    };

// Create a variable to hold the selected pizzas
String[] pickedPizzas = new String[5];

// Create Scanner outside loop
Scanner scanner = new Scanner(System.in);

// Loop to get picked pizzas
for (int i = 0; i < 5; i++) {
    // Save picked pizza, subtracting 1 since arrays start at 0
    pickedPizzas[i] = pizzas[scanner.nextInt() - 1];
}

// Do stuff with the users picked pizzas!
于 2012-05-07T06:09:03.460 回答
0

不要Pizzas在 Java 中对本地原语使用大写单词 ( )。按照惯例,这些是类名。

无论值如何,您都想区分相同的内容——例如,你每次Pizzas递增——并将其排除在 if/else 之外。pizzaCounter如果您需要做的只是获取披萨类型的名称,那么这里有几个示例说明您根本不需要一组案例,您只需要为任何后续使用分配。

如果每个案例有一些独特的东西,您可以使用switch

http://docs.oracle.com/javase/tutorial/java/nutsandbolts/switch.html

顺便说一句,您可以像这样初始化数组:

String eg[] = {
   "one",
   "two",
   "three",
};
于 2012-05-07T06:07:48.843 回答
0
String[] PIZZA_LABELS = new String[]{ "1- Cheese", "2- Wedge" ... }
String label;
while(pizzaCounter < 5)
{
        Scanner pizzaPick = new Scanner(System.in);
        int Pizzas = pizzaPick.nextInt();
        label  = PIZZA_LABELS[Pizzas - 1]; // 1-indexed vs 0-indexed
        ...
        System.out.println(label);

“如果”消失了。(我鼓励您查看 java.util.Map 以获得比标签数组更简洁的数据结构)。

于 2012-05-07T06:02:49.153 回答