对于我的项目,我们必须使用Java来操纵某些LISP语句。其中一项任务是:将除第n个元素之外的所有元素添加到另一个ArrayList中
'((4A)(1B)(2C)(2A)(1D)(4E)2)
最后的数字是“n”。任务是从表达式中删除每个第n个元素。例如,上面的表达式将计算为:
′((4A)(2C)(1D)2)
我现在的做法是将不在第n个索引处的所有元素添加到另一个数组。我的错误是它将每个元素添加到新阵列中,使两个元素相同。
我的代码:
String input4=inData.nextLine();
length=input4.length();
String nString=input4.substring(length-2,length-1);
int n = Integer.parseInt(nString);
count=n;
String delete1=input4.replace("'(","");
String delete2=delete1.replace("(","");
final1=delete2.replace(")","");
length=final1.length();
for (int i=1;i<length;i++)
{
part=final1.substring(i-1,i);
list.add(part);
}
for(int i=0;i<=list.size();i++)
{
if(!(i%n==0))
{
delete.add(list.get(i-1));
delete.add(list.get(i));
}
else
{
}
}
System.out.print("\n"+list);
也许玩弄你的incrementors自(NUM字元)在一次跳跃前进二是2组。你也必须加倍你的模数来补偿。 – 2015-02-11 01:38:28
我的问题是每个字母都带有一个数字。所以如果第n个元素是2,那么我意味着我必须忽略2个索引。如果第n个元素是3,我不得不忽略3个索引。我试图找出正确的逻辑,但我有麻烦@AlexPopov – OoOoOoOoOoO 2015-02-11 02:08:30