栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

【蓝桥杯】备战系列之基础题3.十六进制转十进制,十进制转十六进制

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

【蓝桥杯】备战系列之基础题3.十六进制转十进制,十进制转十六进制

问题描述

  从键盘输入一个不超过8位的正的十六进制数字符串,将它转换为正的十进制数后输出。
  注:十六进制数中的10~15分别用大写的英文字母A、B、C、D、E、F表示。

题目中要求用字符串表示十六进制整数,由于该十六进制数不超过八位,而int型变量的最大值为2^31-1,为2147483647,一个十位数,long long型数据的位数一般为十九位,从-9223372036854775808到9223372036854775807,据题意得该字符串最大为FFFFFFFF,为4294967295,明显大于了int型变量的表示范围,然后采用long long来存储该字符串转化为十进制数之后的值。

解题思路:

首先是十六进制如何转化为十进制的问题,这里利用秦九韶算法,结合进制转换:

十六进制中为0~9,A~F,把遇到的字符串中的A到F这些转化为十进制数,转化语句为:

 if(s[i]>='A'&&s[i]<='F')
            {
                sum=sum*16+s[i]-'A'+10;
               // cout< 

剩下的遇到的十六进制里面的0~9就按依次按权展开转化为十进制数:

else
            {
                sum=sum*16+s[i]-'0';
                //cout< 

最后输出即可。

完整代码如下:

#include
#include
using namespace std;
int main()
{
    string s;
    cin>>s;
        long long sum=0;
        for(int i=0;i='A'&&s[i]<='F')
            {
                sum=sum*16+s[i]-'A'+10;
               // cout< 

二.十进制转十六进制。

利用秦九韶算法,与十六进制转十进制相反,这个首先需要判断输入的十进制数是否为0,然后再进行转换。代码如下:

#include
using namespace std;
int main()
{
    int n;
    string s;
    cin>>n; 
        int k=0;
        if(n==0)
        {
            cout<<"0";
        }
        else
        {
           while(n!=0)
           {
               if(n%16>=10)
               {
                   s[k++]='A'+n%16-10;
               }
               else
               {
                   s[k++]='0'+n%16;
               }
               n=n/16;
           }
           for(int i=k-1;i>=0;i--)
           {
               cout< 

不过这里百思不得其解的是为什么不能用头文件里面的reverse函数,如果有大佬知道能给解释一下蟹蟹啦。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/702932.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号