我一直在练习动态编码,因此在这里我要接受n个测试用例,但是当我输入多个测试用例时,它仅接受一个测试用例。假设我输入测试用例的数量为2,玩家和反派的数量为3,并输入它们的能量,但是它只运行一次迭代,而程序在下一次迭代中结束。如何使其接受许多测试用例?
/* Read input from STDIN. Print your output to STDOUT*/
import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;
import java.util.Scanner;
class Testcase // Name should be in PASCAL
{
int N;
int [] play;
int [] villain;
String status;
public Testcase (int n) { // Constructor
this.N=n;
play = new int [N];
villain=new int [N];
}
}
public class Main {
static List<Testcase> caseno=new ArrayList<Testcase>();
public static void main(String args[] ) throws Exception {
List<Testcase> caseno=new ArrayList<Testcase>();
Scanner sc=new Scanner(System.in);
//int n1=10;
System.out.println("Enter the number of Test Cases:");
int n1=sc.nextInt();
int i,j;
Testcase t;
for(i=0;i<n1;i++)
{
//int n=6;
System.out.println("Enter the number of players and villains:");
int n=sc.nextInt();
t=new Testcase(n);
System.out.println(t.N+" "+t.play.length);
System.out.println("Enter the Player Energies");
for(i=0;i<n;i++)
{
t.play[i]=sc.nextInt();
}
System.out.println("Enter the Villain Energies");
for(i=0;i<n;i++)
{
t.villain[i]=sc.nextInt();
}
Arrays.sort(t.play);
Arrays.sort(t.villain);
}
for(Testcase t1:caseno)
{
for(i=0;i<t1.N;i++)
{
System.out.println(t1.villain[i]+" "+t1.play[i]);
}
int flag=0;
for(i=0;i<t1.N;i++)
{
if(t1.play[i]<t1.villain[i])
{
flag=0;
}
else
{
flag=1;
t1.status="LOSS";
break;
}
}
if(flag==0)
{
t1.status="WON";
}
System.out.println(t1.status);
}
for (Testcase j1:caseno)
{
System.out.println(j1.status);
}
//Write code here
}
}
答案 0 :(得分:1)
您所遇到的问题是变量的可见性。 我将简短地向您展示问题:
int i;
for (i=0; i<2; i++) { // loop 1
for (i=0; i<3; i++) { // loop 2
// do something
}
}
在loop2中,变量i从0到2。在第二个循环退出之后,变量“ i”保留数字3(这就是为什么退出)。因此,由于达到了终止条件(i <2),因此循环1也将退出。但这不是您想要的。
最好克服这样的问题:
for (int i1=0; i1<2; i1++) { // loop 1
for (int i2=0; i2<3; i3++) { // loop 2
// do something
}
}
这样,每个变量都具有自己的作用域,并且不会干扰具有相同名称的其他变量。它将通过循环2(“ i2” == 0,== 1和== 2)运行两次(一次用于“ i1” == 0,另一次用于“ i1” == 1)。
这是您示例中的基本问题。
您可以在此处找到更多信息: