hdu2106(decimal system)

本文介绍了解决HDU2106问题的方法,通过分离数值与进制符号并转换为十进制进行求和。使用Java实现,包括读取输入、解析字符串和计算总和的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

hdu2106

思路:主要将数和进制分开,然后分别换成十进制就行了。这里也可以用上面说的 split() 来做,会跟简单大笑

<pre name="code" class="java">import java.util.*;
class Main{
	public static void main(String args[]){
		Scanner sc=new Scanner(System.in);
		while(sc.hasNext()){
			int n=sc.nextInt();
			int sum=0;
			for(int i=0;i<n;i++){
				String str=sc.next();
				int k=system(str);
				sum+=k;
			}
			System.out.println(sum);
		}
	}
	public static int system(String str){
		boolean sign=true;
		int[] a=new int[20];
		int[] b=new int[10];
		int ka=0;
		int kb=0;
		for(int i=0;i<str.length();i++){
			if(str.charAt(i)==')'){
				break;
			}else if(str.charAt(i)=='('){
				sign=false;
			}else if(sign){
				a[ka]=str.charAt(i)-48;
				ka++;
			}else{
				b[kb]=str.charAt(i)-48;
				kb++;
			}
		}
		/*for(int i=0;i<kb;i++){
			System.out.print(b[i]+" ");
		}System.out.println();*/
		int ss=0;
		int sum=0,s=0;//System.out.println(ka+" "+kb+"*");
		for(int i=0;i<kb;i++){
			sum=s+b[i];
			s=sum*10;
		}//System.out.println(sum);
		for(int i=0;i<ka;i++){
			ss+=a[i]*(int)Math.pow(sum,(ka-1-i));
		}//System.out.println(ss);
		return ss;
	}
}


 

                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值