题目:
给定一个字符串str,求其中全部数字串所代表的数字之和
要求:
-
忽略小数点
-
考虑‘-’,如果有连续奇数个,则为负,如果有连续偶数个,就为正数
例如:
str=“A-1B- -2C- -D6E” return 7
思路:
- 设置变量 res 为目前的累加和,设置变量 num 为当前收集到的数字,设置变量 pos 为将 num 累加到 res 时 num 的正负,起初 res=0,num=0,pos=true;
- 遍历字符串,判断当前字符是否为数字字符,如果是数字字符,cur = ‘当前数字字符’ - ‘0’,例如 str = “123”;当前字符为 ‘1’,cur = 1,num = 1;当前字符为 ‘2’,cur = 2,num = 12;当前字符为 ‘3’,cur = 3,num = 123。再比如 str = “-123”,当前字符为 ‘-’,pos = false,当前字符为 ‘1’,cur = 1,num = -1;当前字符为 ‘2’,cur = 2,num = -12;当前字符为 ‘3’,cur = 3,num = -123;无论是哪种情况,num = num * 10 + (pos?cur:-cur);
- 当前字符如果不是数字,先将 num 的值累加到 res 里,保存之前的结果,累加后,num 清零,再判断当前字符是不是 ‘-’ ,如果不是 ‘-’,pos = true,如果是 ‘-’,看前一个字符,如果前一个字符也是 ‘-’,pos = true,否则为 false
- 当当前字符是非数字字符时,才会将 num 的值累加到 res,但是当最后一个字符是数字字符时,也要将 num 的值累加到 res
public int numSum(String str){
if(str==null){
return 0;
}
int res = 0;
int num = 0;
boolean pos = true;
int cur = 0;
char[] arr = str.toCharArray();
for(int i = 0;i < arr.length;i++){
//如果是数字字符,直接是 num = num*10+(pos?cur:-cur);
//所以处理不是数字字符的情况
cur = arr[i]+'0';
if(cur<0||cur>9){
res+=num;
num = 0;
//判断是否是'-'
if(arr[i]=='-'){
//判断是第一个字符或者前一个字符是否为'-'
if(i-1>-1&&arr[i-1]=='-'){//不是第一个字符,而且前一个字符也是‘-’
pos = !pos;//不能写成pos = true,如果有连续两个以上的'-',pos = true 就错误了
}else{//是第一个字符或者前一个不是‘-’,负号
pos = false;
}
}else{//如果当前字符不是‘-’
pos = true;
}
}else{//是数字字符
num = num * 10+(pos?cur:-cur);
}
}
res+=num;//解决最后一个字符是数字字符的情况,将数字加到结果集里
return res;
}