这是我正在努力的一项编程任务。我目前正在努力解决代码的主要方法。据说,我想要做的是使用isDNASequence方法检查字符串中的各个字符,看它是否在需求范围内,同时还计算输入之间的空间量(例如,如果args输入是aaaa gggg cccc tttt acgt accg atgc gcta tccg< =应该有9个空格)从中制作一个二维数组。我计划首先使用for循环来处理isDNASequence方法,现在由于某种原因,charAt方法不起作用,而且我被困在代码的这一部分。所以任何指针或帮助都非常感激。我是一个非常棒的java noob,如果我问任何愚蠢的话,请原谅我:D
import java.util.ArrayList;
import java.util.List;
public class Hamming {
public static boolean isDNASequence(String s) {
// create an array of acceptable characters
char[] acceptableInput = { 'a', 'c', 'g', 't' };
// render the original string s to lower case into string x
String x = s.toLowerCase();
// for loop to check if all the characters are acceptable characters or
// not
for (int i = 0; i < x.length(); i++) {
boolean isDNASequence = false;
for (int j = 0; j < acceptableInput.length; j++) {
if (x.charAt(i) == acceptableInput[j])
isDNASequence = true;
}
// the output of the boolean
if (isDNASequence == false)
return false;
}
return true;
}
public static int[][] getDistances(String[] sequences) {
// filter out the data and get the number of strings left
List<String> validStrings = new ArrayList<>();
for (int x = 0; x < sequences.length; x++) {
if (isDNASequence(sequences[x])) {
validStrings.add(sequences[x]);
}
}
// create the 2D array
int size = validStrings.size();
int[][] result = new int[size][];
for (int i = 0; i < size; i++) {
result[i] = new int[size];
}
// putting the values from getHammingDistance method into the array cell
for (int z = 0; z < result.length; z++) {
for (int j = 0; j < result[0].length; j++) {
result[z][j] = getHammingDistance(sequences[z], sequences[j]);
}
}
return result;
}
public static int getHammingDistance(String sequence1, String sequence2) {
// Initialise int a, which will be the Hamming distance
int a = 0;
/**
* renders the two strings sequence1 and sequence2 into lower case to
* make it easier to calculate
*/
String sequenceX = sequence1.toLowerCase();
String sequenceY = sequence2.toLowerCase();
/**
* I use the for-loop to calculate the Hamming distance based on
* comparing individual characters of the two strings
*/
for (int x = 0; x < sequenceX.length(); x++) {
if (sequenceX.charAt(x) != sequenceY.charAt(x)) {
a += 1;
}
}
return a;
}
/**
* Main method
*
* 1. Go through the parameters 2. Ensure they are valid DNA sequences 3.
* Get the Hamming distance matrix 4. Print out the highest distance only
*
* @param args
* - program arguments
*/
public static void main(String[] args) {
int d = 0;
for (int q = 0; q < args.length; q++) {
isDNASequence(args.charAt[q]);
} if (args.charAt[q] == " "){
d+=1;
}
}
}
答案 0 :(得分:0)
main方法中的args
是String数组,它们不是char数组
所以,主要方法应该是:
public static void main(String[] args) {
int d = 0;
for (int q = 0; q < args.length; q++) {
isDNASequence(args[q]);
}
if (args[q].equals(" ")){
d+=1;
}
}
如果您希望代码args[q].equals(" ")
检测参数中的空间,我认为您不需要它,因为如果从命令提示符运行代码,则空格将被视为参数的分隔符。
例如,您在命令提示符下运行此类:
> java Hamming aaaa gggg cccc tttt acgt accg atgc gcta tccg
然后,main方法中的args
值为{"aaaa","gggg","cccc","tttt","acgt","accg","atgc","gcta","tccg"}
答案 1 :(得分:0)
charAt
是一个方法,而args是一个String []所以应该使用它args[0].charAt(q)
。
就个人而言,我会做那样的事情。
String arr = args[0].split(" "); //I wouldnt bother with spaces
然后我会做以下事情;
for(int i = 0; i < arr.length; i++){
if(arr[i].length() != 4) //I m assuming in every 4 char there should be space
return false;
for(int j = 0; j < arr[i].length();i++)
return isDNAsequence(arr[i].charAt(j));
}
同时将isDNASequence(String str)
更改为isDNASequence(char c)