[英]Printing out the line number a Char was found on in a String
我正在編寫一個程序來掃描給定字符串中的數學運算符,當程序找到匹配項時,我想返回運算符和找到它的行,下面是我的嘗試。
public class Testing {
public enum TokenType {
OP_MULTIPLY,
OP_DIVIDE,
OP_MOD,
OP_ADD,
OP_SUBTRACT,
OP_LESS,
OP_LESSEQUAL,
OP_GREATER,
OP_GREATEREQUAL,
OP_EQUAL,
OP_NOTEQUAL,
OP_NOT,
OP_ASSIGN,
OP_AND,
OP_OR,
OP_DOT
}
public static String inputString = "public class HelloWorld {\n"
+ " public static void-*//-- main(String[] args) {\n" + " // to print out+8+*+ hello world\n"
+ " System.out.println(\"Hello World!\");\n" + " }\n" + "}\n";
public static void lineNumber(String lineNumber) {
int count = 1;
String[] lines = inputString.split("\\r?\\n");
for (String line : lines) {
System.out.println("line " + count++);
}
int n = inputString.length();
for (int i = 0; i < n; i++) {
char ch = inputString.charAt(i);
getOP(ch);
}
}
public static TokenType getOP(char ch) {
switch (ch) {
case '+':
System.out.println(TokenType.OP_ADD + ", " + ch);
return TokenType.OP_ADD;
case '-':
System.out.println(TokenType.OP_SUBTRACT + ", " + ch);
return TokenType.OP_SUBTRACT;
case '/':
System.out.println(TokenType.OP_DIVIDE + ", " + ch);
return TokenType.OP_DIVIDE;
case '*':
System.out.println(TokenType.OP_MULTIPLY + ", " + ch);
return TokenType.OP_MULTIPLY;
}
return null;
}
public static void main(String[] args) {
lineNumber(inputString);
}
}
這是我目前的 output:
line 1
line 2
line 3
line 4
line 5
line 6
OP_SUBTRACT, -
OP_MULTIPLY, *
OP_DIVIDE, /
OP_DIVIDE, /
OP_SUBTRACT, -
OP_SUBTRACT, -
OP_DIVIDE, /
OP_DIVIDE, /
OP_ADD, +
OP_ADD, +
OP_MULTIPLY, *
OP_ADD, +
我試圖實現的目標:
Line 1: OP_ADD, +
Line 3: OP_MULTIPLY, *
etc.
謝謝
您的代碼可能如下所示:
public class Testing {
enum TokenType {
OP_MULTIPLY,
OP_DIVIDE,
OP_MOD,
OP_ADD,
OP_SUBTRACT,
OP_LESS,
OP_LESSEQUAL,
OP_GREATER,
OP_GREATEREQUAL,
OP_EQUAL,
OP_NOTEQUAL,
OP_NOT,
OP_ASSIGN,
OP_AND,
OP_OR,
OP_DOT
}
public static void main(String[] args) {
lineNumber();
}
public static final String inputString = "public class HelloWorld {\n" +
" public static void-*//-- main(String[] args) {\n" +
" // to print out+8+*+ hello world\n" +
" System.out.println(\"Hello World!\");\n" +
" }\n" +
"}\n";
private static void lineNumber() {
String[] lines = inputString.split("\\r?\\n");
for (int i = 0; i < lines.length; i++) {
String line = lines[i];
for (int j = 0; j < line.length(); j++) {
TokenType tokenType = getOP(line.charAt(j));
if (tokenType != null) {
System.out.printf("Line %d: %s, %s\n", i + 1, tokenType.name(), line.charAt(j));
}
}
}
}
private static TokenType getOP(char ch) {
switch (ch) {
case '+':
return TokenType.OP_ADD;
case '-':
return TokenType.OP_SUBTRACT;
case '/':
return TokenType.OP_DIVIDE;
case '*':
return TokenType.OP_MULTIPLY;
// more
}
return null;
}
}
嵌套循環允許保持當前行索引。 此外,您的getOP
方法應該只負責根據字符值確定數學運算。 它不應該打印任何東西,這是lineNumber
的責任。
Output:
Line 2: OP_SUBTRACT, -
Line 2: OP_MULTIPLY, *
Line 2: OP_DIVIDE, /
Line 2: OP_DIVIDE, /
Line 2: OP_SUBTRACT, -
Line 2: OP_SUBTRACT, -
Line 3: OP_DIVIDE, /
Line 3: OP_DIVIDE, /
Line 3: OP_ADD, +
Line 3: OP_ADD, +
Line 3: OP_MULTIPLY, *
Line 3: OP_ADD, +
您應該對每個單獨的行進行操作檢查,而不是一次對整個輸入進行檢查。
public static void lineNumber (String inputString)
{
int count = 1;
String[] lines = inputString.split("\\r?\\n");
for (String line : lines) {
System.out.println("line " + count++);
int n = line.length();
for (int i = 0; i < n; i++)
{
char ch = line.charAt(i);
getOP(ch);
}
}
}
所以關鍵是在與符號打印相同的循環中獲取行號。 我還添加了一些復雜性以避免打印行號而沒有任何內容。
public class Testing {
public enum TokenType {
OP_MULTIPLY,
OP_DIVIDE,
OP_MOD,
OP_ADD,
OP_SUBTRACT,
OP_LESS,
OP_LESSEQUAL,
OP_GREATER,
OP_GREATEREQUAL,
OP_EQUAL,
OP_NOTEQUAL,
OP_NOT,
OP_ASSIGN,
OP_AND,
OP_OR,
OP_DOT
}
public static String inputString = "public class HelloWorld {\n" +
" public static void-*//-- main(String[] args) {\n" +
" // to print out+8+*+ hello world\n" +
" System.out.println(\"Hello World!\");\n" +
" }\n" +
"}\n";
public static void lineNumber(String lineNumber) {
int count = 0;
String[] lines = inputString.split("\\r?\\n");
for (String line: lines) {
count++;
int n = line.length();
boolean first = true;
for (int i = 0; i < n; i++) {
char ch = line.charAt(i);
if (getOP(ch, first, count) != null) {
first = false;
}
}
System.out.println();
}
}
public static TokenType getOP(char ch, boolean firstOnLine, int lineNum) {
if (firstOnLine && (ch == '+' || ch == '-' || ch == '/' || ch == '*')) {
System.out.print("line " + lineNum + " ");
}
switch (ch) {
case '+':
System.out.println(TokenType.OP_ADD + ", " + ch);
return TokenType.OP_ADD;
case '-':
System.out.println(TokenType.OP_SUBTRACT + ", " + ch);
return TokenType.OP_SUBTRACT;
case '/':
System.out.println(TokenType.OP_DIVIDE + ", " + ch);
return TokenType.OP_DIVIDE;
case '*':
System.out.println(TokenType.OP_MULTIPLY + ", " + ch);
return TokenType.OP_MULTIPLY;
}
return null;
}
public static void main(String[] args) {
lineNumber(inputString);
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.