分割一个字符串并检查它们是否彼此是变位词
To split a string and to check if they are anagram to each other
我正在尝试解决这个问题:https://www.hackerrank.com/challenges/anagram
这是我的代码:
import java.util.*;
public class Anagram {
public static void main(String[] args)
{
Scanner reader = new Scanner(System.in);
int t = reader.nextInt();
while((t--) > 0)
{
String input = reader.nextLine();
if((input.length()) % 2 == 1)
System.out.println(-1);
else
{
int x = input.length();
int q = (int)(Math.floor((x / 2)));
String input1 = input.substring(0, q);
String input2 = input.substring(q, x);
int [] count2 = new int[26];
for(int i = 0; i < input2.length(); i++)
{
char ch2 = input2.charAt(i);
count2[ch2 - 'a']++;
}
// int [] count1 = new int[26];
for(int i = 0; i < input1.length(); i++)
{
char ch1 = input1.charAt(i);
if(count2[i] > 0)
count2[ch1 - 'a']--;
}
int count = 0;
for(int j = 0; j < 26; j++)
{
count = count + Math.abs(count2[j]);
}
System.out.println(count);
}
}
}
}
示例输入
6
aaabbb
ab
abc
mnop
xyyx
xaxbbbxx
预期输出
3
1
-1
2
0
1
我的输出
0
4
1
-1
2
2
谁能告诉我哪里出错了?我找不到错误...
你可以用它来检查两个字符串是否是回文:
String original = "something";
String reverse = new StringBuilder(original).reverse().toString();
boolean anagram = original.equals(reverse);
你的第一个输出总是 0,因为这一行:
int t = reader.nextInt();
接着是 reader.nextLine();
。 Check this post for more details on that。为了快速修复,将该行更改为:
int t = Integer.parseInt(reader.nextLine());
现在,让我们从以下两个陈述开始:
int x = input.length();
int q = (int)(Math.floor((x/2)));
不需要在那里做 Math.floor
。 x/2
是一个整数除法,只会给你整数结果。
进入第二个 for
循环。您使用了以下条件:
if(count2[i]>0)
count2[ch1-'a']--;
注意到条件中的错误了吗?应该是count2[ch1 - 'a'] > 0
。而且,您会错过计数不大于 0 的情况,在这种情况下您将不得不执行 ++
。顺便说一句,因为您无论如何都在做 Math.abs()
,所以您不需要条件。只需做一个 --
:
for( int i = 0; i < input1.length(); i++ ) {
char ch1 = input1.charAt(i);
count2[ch1-'a']--;
}
顺便说一句,最终结果将是 count / 2
,而不是 count
,因为 count
包含从输入 1 到输入 2 的总不匹配,反之亦然。但我们只需要修复其中一个以匹配另一个。所以,只考虑总不匹配的一半。
根据你的问题,主要逻辑可以改成下面这样。
注意 - 我只添加了主要逻辑,并在此处排除了用户输入。
public static void main(String[] args) {
String str = "acbacccbaac";
int len = str.length();
String str1 = null, str2 = null;
if(len %2 != 0) {//check for odd length
str1 = str.substring(0, len/2);
str2 = str.substring(len/2+1, len);
}else {//check for even length
str1 = str.substring(0, len/2);
str2 = str.substring(len/2, len);
}
char[] arr1 = str1.toLowerCase().toCharArray();
Arrays.sort(arr1);
char[] arr2 = str2.toLowerCase().toCharArray();
Arrays.sort(arr2);
if(Arrays.equals(arr1, arr2))
System.out.println("Yes");
else
System.out.println("No");
}
我在我的 HackerRank 配置文件中以这种方式解决了同样的问题,效果很好。
这是我解决问题的方法,很有效!
static int anagram(String s) {
String a = "";
String b = "";
if (s.length() % 2 == 0) {
a = s.substring(0, s.length() / 2);
b = s.substring((s.length() / 2), s.length());
}
if (s.length() % 2 != 0) {
a = s.substring(0, s.length() / 2);
b = s.substring((s.length() / 2), s.length());
}
if (a.length() == b.length()) {
char[] aArray = a.toCharArray();
char[] bArray = b.toCharArray();
HashMap<Character, Integer> aMap = new HashMap<Character, Integer>();
HashMap<Character, Integer> bMap = new HashMap<Character, Integer>();
for (char c : aArray) { // prepare a Hashmap of <char>,<count> for first string
if (aMap.containsKey(c)) {
aMap.put(c, aMap.get(c) + 1);
} else {
aMap.put(c, 1);
}
}
for (char c : bArray) {// prepare a Hashmap of <char>,<count> for second string
if (bMap.containsKey(c)) {
bMap.put(c, bMap.get(c) + 1);
} else {
bMap.put(c, 1);
}
}
int change = 0;
for (Map.Entry<Character, Integer> entry : bMap.entrySet()) {
System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue());
if (!aMap.containsKey(entry.getKey())) {
change += entry.getValue();
} else {
if (entry.getValue() > aMap.get(entry.getKey())) {
change += entry.getValue() - aMap.get(entry.getKey());
} else {
//change += entry.getValue();
}
}
}
return change;
} else {
return -1;
}
}
我正在尝试解决这个问题:https://www.hackerrank.com/challenges/anagram
这是我的代码:
import java.util.*;
public class Anagram {
public static void main(String[] args)
{
Scanner reader = new Scanner(System.in);
int t = reader.nextInt();
while((t--) > 0)
{
String input = reader.nextLine();
if((input.length()) % 2 == 1)
System.out.println(-1);
else
{
int x = input.length();
int q = (int)(Math.floor((x / 2)));
String input1 = input.substring(0, q);
String input2 = input.substring(q, x);
int [] count2 = new int[26];
for(int i = 0; i < input2.length(); i++)
{
char ch2 = input2.charAt(i);
count2[ch2 - 'a']++;
}
// int [] count1 = new int[26];
for(int i = 0; i < input1.length(); i++)
{
char ch1 = input1.charAt(i);
if(count2[i] > 0)
count2[ch1 - 'a']--;
}
int count = 0;
for(int j = 0; j < 26; j++)
{
count = count + Math.abs(count2[j]);
}
System.out.println(count);
}
}
}
}
示例输入
6
aaabbb
ab
abc
mnop
xyyx
xaxbbbxx
预期输出
3
1
-1
2
0
1
我的输出
0
4
1
-1
2
2
谁能告诉我哪里出错了?我找不到错误...
你可以用它来检查两个字符串是否是回文:
String original = "something";
String reverse = new StringBuilder(original).reverse().toString();
boolean anagram = original.equals(reverse);
你的第一个输出总是 0,因为这一行:
int t = reader.nextInt();
接着是 reader.nextLine();
。 Check this post for more details on that。为了快速修复,将该行更改为:
int t = Integer.parseInt(reader.nextLine());
现在,让我们从以下两个陈述开始:
int x = input.length();
int q = (int)(Math.floor((x/2)));
不需要在那里做 Math.floor
。 x/2
是一个整数除法,只会给你整数结果。
进入第二个 for
循环。您使用了以下条件:
if(count2[i]>0)
count2[ch1-'a']--;
注意到条件中的错误了吗?应该是count2[ch1 - 'a'] > 0
。而且,您会错过计数不大于 0 的情况,在这种情况下您将不得不执行 ++
。顺便说一句,因为您无论如何都在做 Math.abs()
,所以您不需要条件。只需做一个 --
:
for( int i = 0; i < input1.length(); i++ ) {
char ch1 = input1.charAt(i);
count2[ch1-'a']--;
}
顺便说一句,最终结果将是 count / 2
,而不是 count
,因为 count
包含从输入 1 到输入 2 的总不匹配,反之亦然。但我们只需要修复其中一个以匹配另一个。所以,只考虑总不匹配的一半。
根据你的问题,主要逻辑可以改成下面这样。
注意 - 我只添加了主要逻辑,并在此处排除了用户输入。
public static void main(String[] args) {
String str = "acbacccbaac";
int len = str.length();
String str1 = null, str2 = null;
if(len %2 != 0) {//check for odd length
str1 = str.substring(0, len/2);
str2 = str.substring(len/2+1, len);
}else {//check for even length
str1 = str.substring(0, len/2);
str2 = str.substring(len/2, len);
}
char[] arr1 = str1.toLowerCase().toCharArray();
Arrays.sort(arr1);
char[] arr2 = str2.toLowerCase().toCharArray();
Arrays.sort(arr2);
if(Arrays.equals(arr1, arr2))
System.out.println("Yes");
else
System.out.println("No");
}
我在我的 HackerRank 配置文件中以这种方式解决了同样的问题,效果很好。
这是我解决问题的方法,很有效!
static int anagram(String s) {
String a = "";
String b = "";
if (s.length() % 2 == 0) {
a = s.substring(0, s.length() / 2);
b = s.substring((s.length() / 2), s.length());
}
if (s.length() % 2 != 0) {
a = s.substring(0, s.length() / 2);
b = s.substring((s.length() / 2), s.length());
}
if (a.length() == b.length()) {
char[] aArray = a.toCharArray();
char[] bArray = b.toCharArray();
HashMap<Character, Integer> aMap = new HashMap<Character, Integer>();
HashMap<Character, Integer> bMap = new HashMap<Character, Integer>();
for (char c : aArray) { // prepare a Hashmap of <char>,<count> for first string
if (aMap.containsKey(c)) {
aMap.put(c, aMap.get(c) + 1);
} else {
aMap.put(c, 1);
}
}
for (char c : bArray) {// prepare a Hashmap of <char>,<count> for second string
if (bMap.containsKey(c)) {
bMap.put(c, bMap.get(c) + 1);
} else {
bMap.put(c, 1);
}
}
int change = 0;
for (Map.Entry<Character, Integer> entry : bMap.entrySet()) {
System.out.println("Key = " + entry.getKey() + ", Value = " + entry.getValue());
if (!aMap.containsKey(entry.getKey())) {
change += entry.getValue();
} else {
if (entry.getValue() > aMap.get(entry.getKey())) {
change += entry.getValue() - aMap.get(entry.getKey());
} else {
//change += entry.getValue();
}
}
}
return change;
} else {
return -1;
}
}