http://poj.org/problem?id=1220

题意:进制转换,把a进制转换为b进制。

如果数据不大的话,那么这个题还是很简单的,但这个题就是数据范围太大,所以这里可以采用短除法来做。

关于短除法,就是把每一位(这里指的每一位是指个位十位之类的)除以要转换的进制的余数在乘以当前进制的值加到下一位去,当前位的值就为商,然后这样一直进行到最后一位(也就是个位)个位在对所须转换的进制在取模,那么这个模就是转换后的结果。多次重复,直到最后一位为0,从后往前看就是答案。

举个例子:50,要从十进制转换为二进制。

十位是5,个位是0,那么首先5/2商为2,余1

下一步就是1*10+0=10,然后个位就变成了10,然后10/2=5余0,0就是结果的个位,

然后下一步就是对25进行操作

2/2商1余0,那么十位就是1,个位就是0*10+5=5.

5/2商2余1,那么结果的十位就是1。

然后对12进行操作,十位是1,1/2商0余1,那么十位就为0了。

个位就是1*10+2=12.12/2商6余0,结果的百位就是0.

因为十位是0,所以只对个位进行操作了,6/2商3余0,千为就是0

3/2商1余1,万位为1.

1/2商0余1,十万位为1,所以50转换为二进制就是110010

 #include <stdio.h>
#include <string.h>
#define l 600 int a,b,ans[l],tmp[l];
char c[l]; int main()
{
int n,k;
scanf("%d",&n);
while(n--)
{
memset(tmp,,sizeof(tmp));
memset(ans,,sizeof(ans));
memset(c,,sizeof(c));
scanf("%d%d%s",&a,&b,c);
int len=strlen(c);
for(int i=,m=len-;i<len;i++,m--){ //这里要注意,要把最低位放在tmp[0],因为始终是取最低位的余数为答案的。
if(c[m]>='A'&&c[m]<='Z'){
tmp[i]=c[m]-'A'+;
continue;
}
if(c[m]>='a'&&c[m]<='z'){
tmp[i]=c[m]-'a'+;
continue;
}
else {
tmp[i]=c[m]-'';
}
}
for(k=;len;){
for(int i=len-;i;i--) //这就是短除法。
{
tmp[i-]+=tmp[i]%b*a;
tmp[i]/=b;
}
ans[k++]=tmp[]%b;
tmp[]/=b;
for(;len>&&!tmp[len-];len--);
}
printf("%d %s\n%d ",a,c,b);
for(int i=k-;i>=;i--) //输出答案,逆序输出
{
if(ans[i]>=&&ans[i]<){
printf("%c",ans[i]-+'A');
continue;
}
if(ans[i]>=){
printf("%c",ans[i]-+'a');
}
else printf("%d",ans[i]);
}
printf("\n\n");
}
return ;
}

poj 1220(短除法)的更多相关文章

  1. POJ 1220 NUMBER BASE CONVERSION(较复杂的进制转换)

    题目链接 题意 : 给你一个a进制的数串s,让你转化成b进制的输出. A = 10, B = 11, ..., Z = 35, a = 36, b = 37, ..., z = 61,0到9还是原来的 ...

  2. poj 1220 NUMBER BASE CONVERSION(短除法进制转换)

    题目连接:1220 NUMBER BASE CONVERSION 题目大意:给出两个进制oldBase 和newBase, 以及以oldBase进制存在的数.要求将这个oldBase进制的数转换成ne ...

  3. Poj(1220),hash

    题目链接:http://poj.org/problem?id=1200 这个题,我真是无限MLE,RE,WA,太伤心了,还是写一下吧.题意很简单(英语很好读),最后看了一下金海峰的思路.果然,应该是我 ...

  4. POJ 1220 高精度/进制转换

    n进制转m进制,虽然知道短除法但是还是不太理解,看了代码理解一些了: 记住这个就好了: for(int k=0;l; ){ for(int i=l ; i>=1 ; i--){ num[i - ...

  5. (高精度运算4.7.26)POJ 1220 NUMBER BASE CONVERSION(高精度数的任意进制的转换——方法:ba1----->10进制----->ba2)

    package com.njupt.acm; import java.math.BigInteger; import java.util.Scanner; public class POJ_1220_ ...

  6. poj 1220 NUMBER BASE CONVERSION

    NUMBER BASE CONVERSION Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 5976   Accepted: ...

  7. 高精度进位制转换,Poj(1220)

    转自ACdream. #include <stdio.h> #include <string.h> #include <stdlib.h> #define MAXS ...

  8. POJ 1220 大数字的进制转换,偷下懒,用java

    题意为进制转换,Java的大数类就像是作弊 import java.math.BigInteger; import java.util.Scanner; public class Main { pub ...

  9. java水题集

    POJ - 1220 进制转换 import java.io.*; import java.util.*; import java.math.*; public class Main { public ...

随机推荐

  1. 【转】【Java】利用反射技术,实现对类的私有方法、变量访问

    java关于反射机制的包主要在java.lang.reflect中,structs,hibernate,spring等框架都是基于java的反射机制. 下面是一个关于利用java的反射机制,实现了对私 ...

  2. html 表格head头部不动 body部分滚动,每格宽同内容增加

    如下图同Excel表格首行固定: <style> .table{ width: 100%; border-collapse:collapse; border-spacing:0;} .ta ...

  3. Effective Objective-C 2.0 — 第14条:理解“类对象“的用意

    每个实例都有一个指向Class 对象的指针,用以表明其类型,而这些 Class 对象则构成了类的继承体系. 如果对象类型无法在编译期确定,那么就应该使用类型信息查询方法来探知. 尽量使用类型信息查询方 ...

  4. OC-Q&A

    How to declare a string in Objective-C ? A C string is just like in C. char myCString[] = "test ...

  5. C-指针

    //格式:变量类型 *变量名//定义了一个指针变量p//指针变量只能存储地址//指针就一个作用:能够根据一个地址值,访问对应的存储空间//指针变量p前面的int:指针变量p只能指向int类型的数据in ...

  6. Yii2.0 实现的短信发送

    原文地址:http://www.phpxs.com/post/4245/ yii2-smserGithub项目主页 https://github.com/daixianceng/yii2-smser ...

  7. 数据库创建用户SQL

    ', default_database=TableName use TableName create user A for login A with default_schema=dbo exec s ...

  8. mysql 总结二(自定义函数)

    本质:mysql内置函数的一种扩展,本质上与mysql内置函数一样. 函数必要条件: @1:参数(非必备): @2:返回值: 模板: create function function_name ret ...

  9. 【Solr】数据库数据导入索引库

    目录 分析框图 配置数据库与solrconfig.xml 回到顶部 分析框图 框图画的粗糙!勿喷啊!勿喷啊! 回到顶部 配置数据库与solrconfig.xml Dataimport插件 可以批量把数 ...

  10. AlwaysOn可用组基础知识

    AlwaysOn可用组概念 AlwaysOn作为SQL Server2012新功能,其目的主要为了替代镜像功能. AlwaysOn拥有镜像的同步和异地容灾功能,并能在镜像的基础上实现一对多的镜像副本同 ...