我有兩個字符串:如何將字符串轉換爲「[]」到一個整數數組
String s1 = "[143, 145, 146, 147, 148, 149, 150, 151, 152, 153, 154, 155, 157, 158, 159, 162, 163, 164]";
String s2 = "[20, 35, 74, 78, 124, 125, 126, 127, 131, 132, 143, 144, 145, 146]";
所有我想要做的就是找到這兩個字符串的最小共同數量。所以我首先取代「[]」符號,並從字符串中提取數字爲整數。然後使用一個循環來找到最小的共同number.The程序如下:
s1 = s1.replace("[","");
s1 = s1.replace("]","");
String [] band = s1.split(",");
s2 = s2.replace("[","");
s2 = s2.replace("]","");
String [] hotel = s1.split(",");
System.out.println(EarliestCommonSlot(hotel,band));
的EarliestCommonSlot()的定義如下:
public static int EarliestCommonSlot(String [] a1, String [] b1){
int i=0,j=0;
int common = -1;
int [] a = new int [a1.length];
int [] b = new int [b1.length];
for(i = 0;i < a1.length;i++)
{
a[i] = Integer.parseInt(a1[i]);
System.out.println(a1[i]);
}
for(i = 0;i < b1.length;i++)
{
b[i] = Integer.parseInt(b1[i]);
System.out.println(b1[i]);
}
i = 0; j=0;
while (i< a.length && j < b.length){
if (a[i] == b[j]){
common = a[i]; break;
}
if (a[i] < b[j]){
i++;
}
else j++;
}
return common;
}
但是當我運行該程序,它具有以下錯誤:
Exception in thread "main" java.lang.NumberFormatException: For input string: " 143"
at java.lang.NumberFormatException.forInputString(NumberFormatException.java:65)
at java.lang.Integer.parseInt(Integer.java:481)
at java.lang.Integer.parseInt(Integer.java:527)
at ClientReserve.EarliestCommonSlot(ClientReserve.java:39)
at ClientReserve.main(ClientReserve.java:179)
這是爲什麼?我怎麼能解決這個問題?
領先的空間是問題所在。嘗試''Integer.parseInt(a1 [i] .trim());''或確保分割的字符串不包含任何空格。 – f1sh