01:数制转换

01:数制转换

总时间限制: 
1000ms

内存限制: 
65536kB
描述

求任意两个不同进制非负整数的转换(2进制~16进制),所给整数在long所能表达的范围之内。
不同进制的表示符号为(0,1,...,9,a,b,...,f)或者(0,1,...,9,A,B,...,F)。

输入
输入只有一行,包含三个整数a,n,b。a表示其后的n 是a进制整数,b表示欲将a进制整数n转换成b进制整数。
a,b是十进制整数,2 =< a,b <= 16。
输出
输出包含一行,该行有一个整数为转换后的b进制数。输出时字母符号全部用大写表示,即(0,1,...,9,A,B,...,F)。
样例输入
15 Aab3 7
样例输出
210306
来源
2005~2006医学部计算概论期末考试

 1 #include<iostream>
 2 #include<cstdio>
 3 #include<cmath>
 4 #include<cstring>
 5 using namespace std;
 6 char a[10001];
 7 int b[10001];
 8 int now;
 9 int tot;
10 int n;//未被转化的进制
11 int m;//需要转换的进制
12 int da[10001];
13 char w[20]={‘A‘,‘B‘,‘C‘,‘D‘,‘E‘,‘F‘};
14 int main()
15 {
16     cin>>n;
17     scanf("%s",&a);
18
19     cin>>m;
20     int l=strlen(a);
21     if(a[0]==‘0‘&&l==1)
22     {
23         cout<<"0";
24         return 0;
25     }
26     for(int i=0;i<l;i++)
27     {
28         if(a[i]>=97&&a[i]<=122)
29         {
30             a[i]=a[i]-32;
31         }
32         if(a[i]>=49&&a[i]<=57)
33         {
34             b[i]=a[i]-48;
35         }
36         else if(a[i]>=65&&a[i]<=90)
37         {
38             b[i]=a[i]-55;
39         }
40     }
41     int ans=0;
42     int now=0;
43     for(int i=l-1;i>=0;i--)
44     {
45         ans=ans+b[i]*(pow(n,now));
46         now++;
47     }
48     int now2=1;
49     while(ans!=0)
50     {
51         int r=ans%m;
52         b[now2]=r;
53         ans=ans/m;
54         now2++;
55     }
56     for(int i=now2-1;i>=1;i--)
57     {
58         if(b[i]<10)
59         cout<<b[i];
60         else
61         {
62             int k=b[i]-10;
63             cout<<w[k];
64         }
65     }
66     /*for(int i=now2;i>=0;i--)
67     cout<<da[i];*/
68     return 0;
69 }

要注意考虑a是0的情况

时间: 2025-01-01 04:56:02

01:数制转换的相关文章

数据结构--栈的基本操作及应用(数制转换)

#include <stdio.h> #include <stdlib.h> #include <malloc.h> #include <math.h> #define TRUE 1 #define FALSE 0 #define ERROR 0 #define INFEASIBLE -1 typedef int Status; typedef int Boolean; typedef int SElemType; #define STACK_INIT_SI

*数组-01. 字符转换

1 /* 2 * Main.c 3 * E1-数组-01. 字符转换 4 * Created on: 2014年8月20日 5 * Author: Boomkeeper 6 ******部分通过********** 7 */ 8 9 #include <stdio.h> 10 11 int main(void) { 12 13 char str[80] = { -1 }; 14 15 gets(str); 16 17 int i; 18 for (i = 0; i < 80; i++)

数制转换

进制的转换可以借助强大的BigInteger,非常的方便. new java.math.BigInteger(num, from).toString(to); 表示num要转换的数从from源数的进制 转换成to的进制. 题目描述 求任意两个不同进制非负整数的转换(2进制-16进制),所给整数在long所能表达的范围之内.     不同进制的表示符号为(0,1,...,9,a,b,...,f)或者(0,1,...,9,A,B,...,F). 输入描述:     输入只有一行,包含三个整数a,n,

7、蛤蟆的数据结构笔记之七栈的应用之数制转换

7.蛤蟆的数据结构笔记之七栈的应用之数制转换 本篇名言:"人生意义的大小,不在乎外界的变迁,而在乎内心的经验." 上面两篇中我们实现了链栈和链队列,接下去哦我们看看实际中栈的应用场景.本次来看下栈在数制转换的作用. 欢迎转载,转载请标明出处: 1.  原理介绍 十进制N和其他进制数的转换时计算机实现计算的基本问题.简单算法如下: N=(N div d )x d + N modd 2.  实现 2.1         定义结构体 定义堆栈的结构体 typedef struct { int

数据结构实践——数制转换(栈)

本文是针对数据结构基础系列网络课程(3):栈和队列的实现项目. [项目 - 数制转换] 把十进制的整数转换为任一进制数输出.请利用栈设计算法,并实现程序. 提示:要转换为r进制,则原来的数逐次除以基数r(除完之后用商再除),直到商为0,得到的一系列余数的逆序就是转换结果.这里的"逆序",意味着后产生的余数,会先输出,后进先出,栈的机会来了-- [参考解答] 解法:头文件sqstack.h请见[顺序栈算法库],使用链栈也可以. #include <stdio.h> #incl

处理数据类型转换,数制转换、编码转换相关的类

MXS&Vincene  ─╄OvЁ  &0000014 ─╄OvЁ  MXS&Vincene MXS&Vincene  ─╄OvЁ:今天很残酷,明天更残酷,后天很美好,但是绝大部分人是死在明天晚上,只有那些真正的英雄才能见到后天的太阳. MXS&Vincene  ─╄OvЁ:We're here to put a dent in the universe. Otherwise why else even be here? 正文>>>>>

java使用链栈实现数制转换

java实现链栈在前面有所介绍:http://www.cnblogs.com/lixiaolun/p/4644141.html 将前面java实现链栈的代码稍作修改: package linkedstack; public class LinkStack { private Element base; private Element top; class Element { public Object data; public Element next; } /** * 初始化栈 * */ pu

Network基础(二):数制转换

一.数制转换 目标: 1)请将下列数字转换为十进制数: (110010011111)2 .(10110101110)2 2)请将下列十进制数转换为二进制: 156.2608.1043 方案: 使用按权展开法将二进制数转换为十进制数,使用短除法除2取余计算十进制数转换为二进制数. 步骤: 步骤一:二进制转十进制 1)二进制数110010011111,转为十进制的结果是3231,转换过程如下: (1100 1001 1111)2     = 1x211+1x210+0x29+0x28+1x27+0x

DS队列+堆栈--数制转换

题目描述 对于任意十进制数转换为k进制,包括整数部分和小数部分转换.整数部分采用除k求余法,小数部分采用乘k取整法例如x=19.125,求2进制转换 整数部分19, 小数部分0.125 19 / 2 = 9 … 1 0.125 * 2 = 0.25 … 0 9 / 2 = 4 … 1 0.25 * 2 = 0.5 … 0 4 / 2 = 2 … 0 0.5 * 2 = 1 … 1 2 / 2 = 1 … 0 1 / 2 = 0 … 1 所以整数部分转为 10011,小数部分转为0.001,合起来