博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
进制问题的几个探究以及拓展
阅读量:6933 次
发布时间:2019-06-27

本文共 2032 字,大约阅读时间需要 6 分钟。

进制问题的几个探究以及拓展

by MedalPluS

   什么是进制这里就不赘述了= =,本文着重讨论如何转换进制

  •    n进制转10进制

   比如说(10001)2如何转换为10进制?

  有一种方法叫做按权展开求和 10001可以展开为20*1+21*0+22*0+23*0+24*1=17,这样就转换为了(17)10

  转换为代码如下:

1 int change_n_to_10(int c[],int k){
//c为n进制数组2 int base=k,result=0,index;3 for(index=len_c-1;i>=0;i--){4 result+=base*c[index];5 base*=k;6 }7 return result;8 }

  时间复杂度O(二进制长度)

  •   10进制转n进制

     算法:短除法

      示意图:

      时间复杂度O(√n)

  • 小数的进制转换

    小数的进制转换同整数转换,小数点前取结果自底向上,小数点后取结果自顶向下

  • 负数的进制转换

    同整数除法,但不过除了以后会有负数取余的情况,会WA,所以要特判,如果有这种情况,当前数应减去那个负进制,并且余数+1

  • 典型例题

   进制转换NOIP2000提高组T1

   【题目描述】

   我们可以用这样的方式来表示一个十进制数: 将每个阿拉伯数字乘以一个以该数字所处位置的(值减1)为指数,以10为底数的幂之和的形式。例如:123可表示为 1*102+2*101+3*100这样的形式。

    与之相似的,对二进制数来说,也可表示成每个二进制数码乘以一个以该数字所处位置的(值-1)为指数,以2为底数的幂之和的形式。一般说来,任何一个正整数R或一个负整数-R都可以被选来作为一个数制系统的基数。如果是以R或-R为基数,则需要用到的数码为 0,1,....R-1。例如,当R=7时,所需用到的数码是0,1,2,3,4,5和6,这与其是R或-R无关。如果作为基数的数绝对值超过10,则为了表示这些数码,通常使用英文字母来表示那些大于9的数码。例如对16进制数来说,用A表示10,用B表示11,用C表示12,用D表示13,用E表示14,用F表示15。

    在负进制数中是用-R 作为基数,例如-15(十进制)相当于110001(-2进制),并且它可以被表示为2的幂级数的和数:

    110001=1*(-2)5+1*(-2)4+0*(-2)3+0*(-2)2+0*(-2)1 +1*(-2)0

    设计一个程序,读入一个十进制数和一个负进制数的基数, 并将此十进制数转换为此负进制下的数:-R∈{-2,-3,-4,...,-20}
  【输入描述】
  输入的每行有两个输入数据。

  第一个是十进制数N(-32768<=N<=32767);  第二个是负进制数的基数-R。
  【输出描述】
  结果显示在屏幕上,相对于输入,应输出此负进制数及其基数,若此基数超过10,则参照16进制的方式处理。
  【分析】
    裸的负数进制转换,没有任何拐弯抹角
1 #include 
2 #include
3 #include
4 using namespace std; 5 6 const int maxn=10001; 7 8 inline int abx(int x){
return x>0?x:-x;} 9 10 int x,y,d,c[maxn],i,a,b;11 12 int main(){13 while(cin>>x>>y){14 d=0;15 printf("%d=",x);16 while(x){17 a=x%y;18 b=x/y;19 if(a<0){20 a-=y;21 b++;22 }23 x=b;24 c[++d]=a;25 }26 for(i=d;i>=1;i--)27 if(c[i]<10)printf("%d",c[i]);28 else printf("%c",(char)('A'+c[i]-10));29 printf("(base%d)\n",y);30 }31 return 0;32 }

                                                                           MedalPluS      

 2015-03-06        

转载于:https://www.cnblogs.com/maopengsen/p/4319488.html

你可能感兴趣的文章
百度开源其NLP主题模型工具包,文本分类等场景可直接使用L——LDA进行主题选择本质就是降维,然后用于推荐或者分类...
查看>>
Oracle11g创建表空间
查看>>
try~Catch语句中异常的处理过程
查看>>
贝塞尔曲线与CAShapeLayer的关系以及Stroke动画
查看>>
阅读《Android 从入门到精通》(29)——四大布局
查看>>
IT运维的定义
查看>>
Temporary ASP.Net Files探究
查看>>
CSDN开源夏令营 百度数据可视化实践 ECharts(8)
查看>>
poj 1284 Primitive Roots(原根+欧拉函数)
查看>>
OpenJudge百炼习题解答(C++)--题4010:2011
查看>>
Oracle PL/SQL语句基础学习笔记(上)
查看>>
MVC,MVP 和 MVVM 的图示
查看>>
正則表達式常见例题
查看>>
STM32 使用 FreeRTOS过程记录
查看>>
ASP.NET Core身份认证服务框架IdentityServer4(2)-整体介绍
查看>>
P1064 金明的预算方案
查看>>
在 Spring 4.3.9下升级 Velocity 1.7.x to Velocity 2.0.x 出现的问题
查看>>
Python排序dict之list数组
查看>>
OKR
查看>>
cmake 常用变量和常用环境变量查表手册
查看>>