gpt4 book ai didi

java - 检查多个 vector 是否是回文?

转载 作者:行者123 更新时间:2023-12-01 13:38:39 24 4
gpt4 key购买 nike

我创建了一个程序,它从文件中读取String,并检查它是否是回文。现在我需要更改它以检查 vector 是否是回文。我必须创建几个 vector 并检查它们是否是回文。假设我有以下 vector

(1,2,3), (1,1,1), (2,2,2), (2,2,2), (1,1,1), (1,2,3)

该程序将使用两个迭代器,并检查第一个迭代器是否等于最后一个,第二个迭代器是否等于倒数第二个,依此类推。这是我的 String 输入程序:

import java.io.BufferedReader;
import java.io.FileReader;
import java.io.IOException;
import java.util.ArrayList;
import java.util.LinkedList;
import java.util.Queue;
import java.util.Stack;
import java.util.Vector;

public class Project4
{
public static void main(String[] args) throws IOException
{
Vector v1 = new Vector(3);
Vector v2 = new Vector(3);
Vector v3 = new Vector(3);
Vector v4 = new Vector(3);
ArrayList vectors = new ArrayList();
v1.add(1);
v1.add(2);
v1.add(3);
v2.add(1);
v2.add(1);
v2.add(1);
v3.add(1);
v3.add(1);
v3.add(1);
v4.add(1);
v4.add(2);
v4.add(3);
vectors.add(v1);
vectors.add(v2);
vectors.add(v3);
vectors.add(v4);
if (isPalindrome(vectors))// If true, it's a palindrome
System.out.println("That is a palindrome.");
else // otherwise, it's not
System.out.println("That is not a palindrome.");

}
public static boolean isPalindrome(ArrayList vectors)
{
// Make a new queue, stack, and character object
Queue<Vector> q = new LinkedList<>();
Stack<Vector> s = new Stack<>();
for(int i = 0; i < vectors.size(); i++){
q.add((Vector) vectors.get(i));
s.add((Vector) vectors.get(i));
}
Vector temp = new Vector();
int mismatches = 0;
for (int i = 0; i < vectors.size(); i++)
{
temp = (Vector) vectors.get(i);
if (vectors.get(i).equals(vectors.get(i)))
{
q.add(temp);
s.push(temp);
}
}

while (!q.isEmpty())
{
if (q.remove() != s.pop())
mismatches++; // Increment "mismatches" if q != s
}

return (mismatches == 0); // will return true if the method did not change the variable "mismatches"
}
}

最佳答案

尝试以下操作(非常简单)。阅读代码中的注释以了解其工作原理。

代码:

public static void main(String[] args)
{
int[] a = { 1, 2, 3 };
int[] b = { 1, 2, 1 };
int[] c = { 1, 2, 2, 1 };
int[] d = { 1, 2, 3, 1 };
int[] e = { 1 };
System.out.println(is_palindrome(a));
System.out.println(is_palindrome(b));
System.out.println(is_palindrome(c));
System.out.println(is_palindrome(d));
System.out.println(is_palindrome(e));

}

public static boolean is_palindrome(int[] arr)
{
for (int i = 0; i < arr.length / 2; i++) { // Check just half times the size of 'arr'
// System.out.println(arr[i] + " - " + arr[arr.length - i - 1]); // Debug
if (arr[i] != arr[arr.length - i - 1]) // Check 'first' with 'last', 'second' with 'last - 1' ...
return false;
}
return true;
}

输出:

false
true
true
false
true

关于java - 检查多个 vector 是否是回文?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21037206/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com