C语言调用函数编写把十进制整数n转换成十六进制怎么编程?
5个回答
推荐于2017-09-29 · 知道合伙人教育行家
关注
展开全部
思路:十进制整数转换为十六进制整数采用"除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
*/
展开全部
调用系统函数strtol。我觉得你这个问题:把十进制整数n转换成十六进制怎么编程 本身就有问题,十进制整数n转换成十六进制只是显示方式不一样而已,在计算机内部其实都是按二进制存储的。比如int i; i=96和i=0x60你按%d打印出来的是一样的。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#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');
}
#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');
}
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
简单方法之一:
#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;
}
#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
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include<stdio.h>
int main()
{
int n;
scanf("%d",&n);
printf("%x\n",n);
return 0;
}
int main()
{
int n;
scanf("%d",&n);
printf("%x\n",n);
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询