字符串问题之 字符串中的数字子串求和

字符串问题之 字符串中的数字子串求和

要求

 1、 忽略小数点 如 A1.3 包含的是两个数字 1 和 3

 2、紧贴数字子串的左侧出现字符“-”   连续次数为奇数时候 为负数 , 偶数时候为正数。

   比如: “A-1BC--12”   其中包含数字为-1 和 12

  str="A1CD2E33"  返回36

  str="A-1B-2C--D6E"  返回7

这个题目的实现方法有很多种,下面我来给大家演示一种哈~~~~~

这个题目就是实现 如何从左到右遍历str时,准确收集每个数字并累加起来

    实现步骤:

    三个变量 int  res  表示目前的累加和

                  int num 表示当前收集到的数字

                   boolean posi 表示如果把num累加到res里, num是正还是负 

                

 

package TT;

public class test2 {

     public static int numSum(String str){
         
         if(str==null){
             return 0;
         }
         
         
         char[] charArr = str.toCharArray();
         int res = 0;
         int num =0;
         boolean posi = true;
         int cur = 0;
         for(int i =0; i<charArr.length; i++){
             cur = charArr[i]-'0';
             if(cur<0 || cur>9){
                 res+=num;
                 num = 0;
                 if(charArr[i]=='-'){
                     
                     if(i-1>-1 && charArr[i-1]=='-'){
                         posi=!posi;
                     }else{
                         posi = true;
                     }
                     
                 }
             }else{
                 num = num * 10 + (posi ? cur : -cur);
             }
             
             
         }
         
         
         res += num;
         return res;
         
         
     }    
    
    

    public static void main(String[] args){
         String str ="A1CD2E33";
           int a = numSum(str);
           System.out.println(a);
        
    }
    
    

    
}

结果:36

 

posted @ 2017-08-14 20:13 toov5 阅读( ...) 评论( ...) 编辑 收藏
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值