我正在开发一个 Java 项目,但遇到了问题。我想对列表/数组 c 中的两个列表或数组 a 和 b 进行减法,但我不知道该怎么做。我希望“a[i] -b[i]”应该在下一个列表 c 中,其中值应该是
c[i]
类似地对于 5-2=3 任何建议和帮助将不胜感激。
代码:
public static void länge() {
{
BufferedReader br = null;
try {
br = new BufferedReader(new FileReader(new File("C:\\Users/Voodoothechild/Desktop/Pidata/Anfang.txt")));
String line = null;
while ((line = br.readLine()) != null) {
{
BufferedReader bro = null;
try {
bro = new BufferedReader(new FileReader(new File("C:\\Users/Voodoothechild/Desktop/Pidata/Ende.txt")));
String lines = null;
while ((lines = br.readLine()) != null) {
String[] anfang = line.split("\n");
String[] ende = lines.split("\n");
List<Integer> an = new ArrayList<Integer>();
List<Integer> en = new ArrayList<Integer>();
for (int index = 0 ; index<ende.length ; index++) {
an.add(Integer.parseInt(anfang[index]));
en.add(Integer.parseInt(ende[index]));
Integer[] anf = new Integer[an.size()];
int[] result = new int[anf.length];
for (int i = 0; i < result.length; i++) {
result[i] = anf[i] - end[i];
}
}
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
if (bro != null) {
try {
bro.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
}
}
} catch(FileNotFoundException e) {
e.printStackTrace();
} catch(IOException e) {
e.printStackTrace();
} finally {
if (br != null) {
try {
br.close();
} catch(IOException e) {
e.printStackTrace();
}
}
}
}
}
使用 Stream API 可以轻松完成:
int[] list1 = {4,2,1};
int[] list2 = {2,2,-1};
IntStream.range(0, list1.length)
.mapToObj(i -> list1[i] - list2[i])
.collect(Collectors.toList());
或者使用 Javaslang 更容易:
Stream.range(0, list1.length)
map(i -> list1[i] - list2[i]);
或者将两个列表压缩在一起:
List.ofAll(list1)
.zip(List.ofAll(list2))
.map(t -> t._1 - t._2);
它非常简单。在解决编程问题之前。始终按步骤进行。以你的问题为例。您需要从 2 个带有值的数组中减去值。
int[] list1 = {4,2,1};
int[] list2 = {2,2,-1};
现在你有 2 个列表。好的,下一步,编写一个循环来遍历列表。但首先要确保两个列表的长度相同,否则你会得到一个不反弹的索引。
for(int i =0; i< list1.length; i++)
{
list3[i] = list1[i] - list2[i];
}
无论如何,这是完整的答案。一定要明白哦
公开课减法 {
public static void main(String[] args)
{
int[] list1 = {4,2,1};
int[] list2 = {2,2,-1};
int[] list3 = new int[list1.length];
//Looping the list
for(int i =0; i< list1.length; i++)
{
list3[i] = list1[i] - list2[i];
}
//Print Statement
for(int j =0; j< list3.length; j++)
{
System.out.println(list3[j]);
}
}
}
这是一个非常简单的答案,您可以将其应用到您的程序中。
public static void main(String[] args) {
int[] a = new int[4];
int[] b = new int[4];
int[] c = new int[4];
a[0] = 5;
a[1] = 12;
a[2] = 20;
a[3] = 50;
b[0] = 1;
b[1] = 2;
b[2] = 3;
b[3] = 4;
for(int i=0; i<a.length; i++){
c[i] = a[i] - b[i];
System.out.println(c[i]);
}
}
答案是Collection类的方法removeAll
ArrayList<Integer> s1 = new ArrayList<Integer>(Arrays.asList(a1));
ArrayList<Integer> s2 = new ArrayList<Integer>(Arrays.asList(a2));
s1.removeAll(s2);
Integer[] result = s1.toArray(new Integer[s1.size()]);
public static void findMinus(int[] arr1, int[] arr2) {
int[] minusResult;
if (arr1.length < arr2.length) {
minusResult = new int[arr2.length];
for (int i = 0; i < arr1.length; i++) {
minusResult[i] = arr1[i] - arr2[i];
}
for (int i = arr1.length; i < arr2.length; i++) {
minusResult[i] = arr2[i];
}
} else {
minusResult = new int[arr1.length];
for (int i = 0; i < arr2.length; i++) {
minusResult[i] = arr1[i] - arr2[i];
}
for (int i = arr2.length; i < arr1.length; i++) {
minusResult[i] = arr1[i];
}
}
//Displaying the output
for (int i : minusResult) {
System.out.println(i);
}
}