java大数进制转换

x 进制 的 z 转换成 y 进制


```java
import java.io.*;
import java.math.BigInteger;
import java.util.*;
public class Main{
    public static void main(String args[]) throws Exception {
    	
        Scanner cin=new Scanner(System.in);
        
        BigInteger x=cin.nextBigInteger();
        
        BigInteger y=cin.nextBigInteger();
        
        String z=cin.next();
        
		BigInteger bas=new BigInteger("1"),ans=new BigInteger("0");
		
        for(int i=z.length()-1;i>=0;i=i-1){
            char c=z.charAt(i);
        	ans=ans.add(bas.multiply(calu(c)));//System.out.println(calu(c));System.out.println(c);
        	bas=bas.multiply(x);
        }
        
        char a[]=new char [200100];
        //System.out.println(ans);
        //System.out.println(x);System.out.println(y);
        int cnt=0;
        BigInteger zo=new BigInteger("0");
        for(;;){
        	cnt=cnt+1;
        	a[cnt]=change(ans.mod(y));
        	
        	ans=ans.divide(y);
        	if(ans.compareTo(zo)==0){
        		break;
        	}
        }
        for(int i=cnt;i>=1;i--){
        	System.out.print(a[i]);
        }
        
    }

	private static char change(BigInteger mod) {
		// TODO Auto-generated method stub
		BigInteger zo=new BigInteger("0"),on=new BigInteger("1");
		BigInteger i = new BigInteger("0");
		char k='0';
		for(;k<='9';i=i.add(on)){
			if(i.compareTo(mod)==0) return k;
			k++; 
		}
		k='A';
		for(;k<='Z';i=i.add(on)){
			if(i.compareTo(mod)==0) return k;
			k++; 
		}
		k='a';
		for(;k<='z';i=i.add(on)){
			if(i.compareTo(mod)==0) return k;
			k++; 
		}
		return k;
		
	}

	private static BigInteger calu(char c) {
		// TODO Auto-generated method stub
		char m='0';  BigInteger w=new BigInteger("1");
		
		int k=0;
		for(BigInteger i=new BigInteger("0");k<=9;i=i.add(w)){
			if(m==c) return i;
			m++;k++;
		}
		k=1;m='A';
		for(BigInteger i=new BigInteger("10");k<=26;i=i.add(w)){
			//System.out.println(i);
			if(m==c) {return i;}
			m++;k++;
		}
		
		k=1;m='a';
		for(BigInteger i=new BigInteger("36");k<=26;i=i.add(w)){
			if(m==c) return i;
			m++;k++;
		}
		return w;
	}
}

全部评论

相关推荐

昨天 10:10
已编辑
门头沟学院 人工智能
写这篇之前我犹豫了挺久。一方面是怕被人骂,&quot;又一个收割焦虑的转行帖&quot;;另一方面是看了太多用&nbsp;GPT&nbsp;套娃出来的「学习路线」文章,AI&nbsp;味重得让人没法读完。所以这篇全是亲身踩过的坑,时间线、用过的项目、当时的心路全都尽量原样写出来。如果你是大学生在迷茫要不要转&nbsp;AI,或者已经在转的路上,希望能给点参考。&nbsp;一个反共识的开场:你以为进&nbsp;OpenAI&nbsp;的人都是博士?&nbsp;先讲个故事,跟我没关系,但跟所有想转&nbsp;AI&nbsp;的人都有关系。&nbsp;OpenAI&nbsp;的&nbsp;Sora&nbsp;团队(就是搞文生视频那个)一共&nbsp;13&nbsp;个人。这里面有两个人特别有意思:&nbsp;Will&nbsp;DePue,密歇根大学计算机系,直接辍学了。17...
_hengheng:我也本,也算是做ai相关,我最开始感觉做ai工程师有多么多么困难,后来发现懂了原理后整体训练完全可以看成一个流程化的内容,开源方案太多了,大多基本都是按着模子在自家业务上做各种操作,就算是大厂的小部门也没那么多资源去训基模,反而更多的是像怎么把技术往业务方向靠近了,不过当前时代如果本科学历没那么好加上自己执行力不是特别强还真不建议走ai工程师这条路,可以试试其他ai的偏业务方向,不然校招不太好杀出来
点赞 评论 收藏
分享
想做乐观锁:都不用AI,咱们都古法编程吧,让节奏慢一点
点赞 评论 收藏
分享
04-13 09:56
已编辑
嵌入式工程师
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务