4 回答

TA貢獻1884條經驗 獲得超4個贊
使用正則表達式很容易做到這一點,因為包含至少三個數字的字符串集是正則語言- 正是正則表達式旨在識別的語言。
public?boolean?hasThreeDigits(String?s)?{ ????return?s.matches(".*\\d.*\\d.*\\d.*"); }
正則表達式.*\d.*\d.*\d.*
將三個數字與其之前、之后或之間的任何內容相匹配。

TA貢獻1847條經驗 獲得超11個贊
為什么不使用計數器并循環每個字符,然后測試它是否是數字?
這是偽代碼:
System.out.print("Enter a string: "); //111Hello <-- valid
String word = input.nextLine();
int numberOfDigits = countDigits(word, 3);
if (numberOfDigits) >= 3{//...
int countDigits(String val, int max){
int cnt = 0;
for(int i =0; i < val.length(); i++){
char c = val.charAt(i);
if(Character.isDigit(c){
cnt++;
}
if(cnt == max)return;
}
return cnt;
}
https://docs.oracle.com/javase/7/docs/api/java/lang/Character.html#isDigit(char)

TA貢獻1936條經驗 獲得超7個贊
讓我們用正則表達式來做到這一點。這似乎并不是真正需要的,但我們假設這是一個作業:
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class FindDigits {
public static final Pattern DIGIT_PATTERN = Pattern.compile("\\p{Digit}");
private static int countDigits(String input) {
final Matcher m = DIGIT_PATTERN.matcher(input);
int c = 0;
while (m.find()) {
c++;
}
return c;
}
public static void main(String[] args) {
for (int i = 0; i < args.length; i++) {
final int c = countDigits(args[i]);
System.out.printf("Input : \"%s\"%nOutput: %s%n", args[i], c >= 3 ? "Valid" : "Invalid");
}
}
}
該答案假設輸入是命令行上的一組字符串。它定義了一個函數來計算由單個數字組成的模式的出現次數。當然也可以到3就停止計數。
我主要發布這個,因為Matcher.find它經常被忽視,因為它沒有在String. 它通常使閱讀正則表達式變得更加容易,因為您不需要定義您不需要的內容。否則,您將陷入正則表達式字符串之類的困境,".*\\d.*\\d.*\\d.*"這些字符串有點可怕并且無法很好地擴展。
除了 while 循環之外,您還可以m.results().count()在更高版本的 Java 運行時上使用。在這種情況下,一句臺詞將是:
long count = Pattern.compile("\\p{Digit}").matcher(input).results().count();

TA貢獻1806條經驗 獲得超5個贊
也許不是最優雅的解決方案,但非常簡短明了:
System.out.println(input.replaceAll("\\D","").length() > 2);
我最喜歡kaya3的解決方案
添加回答
舉報