C语言编程:怎么把一个十进制数转换成为一个十六进制数?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C语言编程:怎么把一个十进制数转换成为一个十六进制数?相关的知识,希望对你有一定的参考价值。
第一种:用来糊弄老师的,输入一个数采用16进制格式输出#include <stdio.h>
int main()
int num = 0;
scanf("%d", &num);
printf("%x", num);
return 0;
第二种:
#include <stdio.h>
#include <string.h>
char oNumTable[6] = 'A', 'B', 'C', 'D', 'E', 'F';
void dToO(int, char*);
int main()
int dNum;
char oNum[100] = 0;
//输入一个十进制数
scanf("%d", &dNum);
//调用转换函数,将十进制转换成以字符串表示的十六进制
dToO(dNum, oNum);
//输出以字符串表示的16进制数据
printf("%s\n", oNum);
return 0;
void dToO(int dNum, char* oNum)
char temp[100] = 0;
for (int i = 0; (dNum) && (i < 100) ; i++)
temp[i] = (dNum % 16);
if (temp[i] > 9)
temp[i] = oNumTable[temp[i] - 10];
else
temp[i] += '0';
dNum /= 16;
char* p = temp;
while (*(p+1)) p++;
for (int i = 0; p != temp - 1; i++, p--)
oNum[i] = *p;
参考技术A #include <stdio.h>
int main()
int x;
printf ("请输入十进制:");
scanf("%d",&x);
printf("十六进制:%x",x);
return 0;
参考技术B #include <stdio.h>
#include <string.h>
int main()
int i=0,p,n;
char b[10];
scanf("%d",&n);
while(n!=0)
p=n%16;
if(p>9) b[i++]='A'+p-10;
else b[i++]='0'+p;
n/=16;
b[i]='\0';
for(i=strlen(b)-1;i>=0;i--)
printf("%c",b[i]);
return 0;
C语言调用函数编写把十进制整数n转换成十六进制怎么编程?
思路:十进制整数转换为十六进制整数采用"除16取余,逆序排列"法。
具体做法是:用16整除十进制整数,可以得到一个商和余数;再用16去除商,又会得到一个商和余数,如此进行,直到商为0时为止,然后把先得到的余数作为十六进制数的低位有效位,后得到的余数作为十六进制数的高位有效位,依次排列起来。
参考代码:
#include "stdio.h"int main()
int num,a[100],i=0,m=0;
char hex[16]=\'0\',\'1\',\'2\',\'3\',\'4\',\'5\',\'6\',\'7\',\'8\',\'9\',\'A\',\'B\',\'C\',\'D\',\'E\',\'F\';
scanf("%d",&num);
while(num>0)
a[i++]=num%16;
num=num/16;
printf("转化为十六进制的数为:");
for(i=i-1;i>=0;i--)//倒序输出
m=a[i];
printf("%c",hex[m]);
printf("\\n");
/*
运行结果:
17
转化为十六进制的数为:11
*/ 参考技术A 调用系统函数strtol。我觉得你这个问题:把十进制整数n转换成十六进制怎么编程 本身就有问题,十进制整数n转换成十六进制只是显示方式不一样而已,在计算机内部其实都是按二进制存储的。比如int i; i=96和i=0x60你按%d打印出来的是一样的。 参考技术B #include <malloc.h>
#include <iostream>
#include<string>
#include<cctype>
#define STACKSIZE 50
#define STACKINCREMENT 20
#define OVERFLOW -1
#define OK 1
#define ERROR -1
using namespace std;
typedef struct
int *base;
int *top;
int stacksize;
Stack;
int InitStack(Stack &s) //创建一个空栈
s.base=(int*)malloc(STACKSIZE*sizeof(int));
if(!s.base)
return (OVERFLOW);
s.top=s.base;
s.stacksize=STACKSIZE;
return (OK);
int Push(Stack &s,int e) //入栈
if((s.top-s.base)>=s.stacksize)
s.base=(int*)realloc(s.base,(STACKSIZE+STACKINCREMENT)*sizeof(int));
if(!s.base)
return(OVERFLOW);
s.top=s.base+s.stacksize;
s.stacksize+=STACKINCREMENT;
*s.top++=e;
return (OK);
int Empty(Stack s) //判断栈是否为空
if(s.base==s.top)
return(1);
else
return(0);
int * Pop(Stack &s,int *e)
if(Empty(s))
return (NULL);
e=--s.top;
return e;
void main()
int i,*e;
e=new int ;
int *getResult;
getResult=new int ;
char ch;
do
cout<<"请输入一个正整数: "<<endl;
cin>>i;
Stack s;
InitStack(s);
while(i)
Push(s,i%16);
i=i/16;
cout<<"转为的16进制数为: "<<endl;
while(!Empty(s))
e=Pop(s,getResult);
if(e!=NULL)
cout<<*e;
cout<<endl;
cout<<"您想继续求解十六进制吗?请输入您的选择(y/n)"<<endl;
cin>>ch;
if(isupper(ch)==1)
ch=tolower(ch);
while(ch!='n');
本回答被提问者和网友采纳 参考技术C 简单方法之一:
#include <iostream>
#include <stdio.h>
using namespace std;
int main(void)
int num;
char buf[100];
cin>>num;
itoa(num,buf,16);
cout<<buf<<"\n";
return 0;
参考资料:还有其他方法可以参考http://hi.baidu.com/hong3088/blog/item/6f8a802e93bf003f1e3089d1.html
参考技术D #include<stdio.h>int main()
int n;
scanf("%d",&n);
printf("%x\n",n);
return 0;
以上是关于C语言编程:怎么把一个十进制数转换成为一个十六进制数?的主要内容,如果未能解决你的问题,请参考以下文章
C语言怎么将超大的16进制数转换成10进制,这个16进制数是个大数,比如0x123456789ABCDEF12345这种