我有下一个代码,它得到一个数字,我需要将该数字分成几个部分,firstPart应该是没有最后一个数字的整数,而secondPart应该只是原始数字的最后一个数字。< / p>
public Boolean verificationNumberFiscalId(String fiscalId) {
// Trying to do a better wa yto do it
Integer firstPart = fiscalId.length()-1;
Integer secondPart = ??????????;
// My old logic
String NitValue = "";
for (Integer i = 0; i < fiscalId.length()-1; i++) {
NitValue = fiscalId.substring(i,1);
}
Integer actualValueLength = fiscalId.length()-1;
String digitoVerificador = fiscalId.substring(actualValueLength,1);
return this.generateDigitoVerification(NitValue) == digitoVerificador;
}
/**
* @param nit
* @return digitoVerificador
* @comment: Does the math logic
*/
public String generateDigitoVerification(String nit) {
Integer[] nums = { 3, 7, 13, 17, 19, 23, 29, 37, 41, 43, 47, 53, 59, 67, 71 };
Integer sum = 0;
String str = String.valueOf(nit);
for (Integer i = str.length() - 1, j=0; i >= 0; i--, j++) {
sum += Character.digit(str.charAt(i), 10) * nums[j];
}
Integer dv = (sum % 11) > 1 ? (11 - (sum % 11)) : (sum % 11);
return dv.toString();
}
你能建议我更好的方法吗?谢谢!
答案 0 :(得分:11)
int x = 1343248724;
int firstpart = x/10;
int secondpart = x%10;
System.out.println(firstpart);
System.out.println(secondpart);
如果你修改10,Mod(%)会给你剩下的最后一位数字 除数将减去最后一位数。这样你就不必实际搜索字符串。
做所有长度的东西似乎有点像我一样
哦,要把你的param作为int我会用
Interger.decode(fiscalId);
答案 1 :(得分:2)
这是你获取整数的方法:
Integer firstPart = Integer.valueOf(
fiscalId.substring(0,fiscalId.length()-1));
Integer secondPart = Integer.valueOf(
fiscalId.substring(fiscalId.length()-1));
但我建议改为:
int firstPart = Integer.parseInt(fiscalId.substring(0,fiscalId.length()-1));
int secondPart = Integer.parseInt(fiscalId.substring(fiscalId.length()-1));
答案 2 :(得分:0)
String.valueOf()
n
,使用它的子串(0,n-1)作为第一个新字符串。将最后一个字符(n)用于第二个字符串Integer.valueOf()
将两个字符串转换回整数。