(帮偶看看)从十进制到十六进制的算法~~~~~~~~~

发布于 2022-06-24 18:06:45 字数 2119 浏览 7 评论 2

#include<iostream.h>;

char change(int num);

struct stack

{int *top;

int *base;

};

void initstack(stack &s)

{s.top=s.base=new int[100];

}

void pop(stack &s,int &p)

{p=*(--s.top);

}

void push(stack &s,int p)

{*(s.top++)=p;

}

int main()

{

        int num;

        int yushu=0;

        stack s;

    initstack(s);

        int temp;

        cin>;>;num;

        while(num!=0)

        {   

                yushu=num%16;

                num=num/16;

                push(s,yushu);

                }

        while(s.top!=s.base)

        {pop(s,temp);

        cout<<change(temp);}

        cout<<"H"<<endl;

}

char change(int num)

{

        switch(num)

        {

        case 10: return 'A';break;

    case 11: return 'B';break;

    case 12: return 'C';break;

        case 13: return 'D';break;

        case 14: return 'E';break;

        case 15: return 'F';break;

        }

        return num+48;

}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

好菇凉咱不稀罕他 2022-06-26 13:26:36

其实如果不限定toHex()的参数一定是int的话,可以直接

  1. char* c = (char*)malloc(MAX_C * sizeof(char));
  2. sprintf(c, "%x", argv[1]);

复制代码

一杆小烟枪 2022-06-25 23:18:15
  1. /* hex.c */
  2. #include <stdio.h>;
  3. #define MAX_C 16
  4. char* toHex(int i)
  5. {
  6.         char* c = (char*)malloc(MAX_C * sizeof(char));
  7.         sprintf(c, "%x", i);
  8.         return c;
  9. }
  10. int main(int argc, char** argv)
  11. {
  12.         printf("%sn", toHex(atoi(argv[1])));
  13.         return 0;
  14. }

复制代码
# gcc -o hex hex.c
# ./hex 12345
没有错误处理和参数判断,只是一个原型

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文