博客
关于我
十六进制用strtol()函数转换为十进制
阅读量:388 次
发布时间:2019-03-05

本文共 852 字,大约阅读时间需要 2 分钟。

题目:

输入一个以#结束的字符串,本题要求滤去所有的非十六进制字符(不分大小写),组成一个新的表示十六进制数字的字符串,然后将其转换为十进制数后输出。如果在第一个十六进制字符之前存在字符“-”,则代表该数是负数。

#include
#include
int main(void){ int i,j,k=0,wei; long value; char a[100],b[100],*end; char shi[]="0123456789abcdefABCDEF"; fgets(a,100,stdin); for(i=0;i<(int)strlen(a);i++) { for(j=0;j<(int)strlen(shi);j++) { if(a[i]==shi[j]) { if(k==0) wei=i; b[k]=a[i]; k=k+1; } } } for(i=0;i
=0;j--) b[j+1]=b[j]; b[0]='-'; k++; break; } } printf("%ld",strtol(b,&end,16));}

还可以利用ascll码将数组b中的a-f转化为10-15,(a-f:字符-87,A-F:字符-55),然后利用pow()函数转换,但是这样做数据很容易溢出。

转载地址:http://oiqwz.baihongyu.com/

你可能感兴趣的文章
MySQL底层概述—5.InnoDB参数优化
查看>>
MySQL底层概述—6.索引原理
查看>>
MySQL底层概述—7.优化原则及慢查询
查看>>
MySQL底层概述—8.JOIN排序索引优化
查看>>
MySQL底层概述—9.ACID与事务
查看>>
Mysql建立中英文全文索引(mysql5.7以上)
查看>>
mysql建立索引的几大原则
查看>>
Mysql建表中的 “FEDERATED 引擎连接失败 - Server Name Doesn‘t Exist“ 解决方法
查看>>
mysql开启bin-log日志,用于canal同步
查看>>
MySQL开源工具推荐,有了它我卸了珍藏多年Nactive!
查看>>
MySQL异步操作在C++中的应用
查看>>
MySQL引擎讲解
查看>>
Mysql当前列的值等于上一行的值累加前一列的值
查看>>
MySQL当查询的时候有多个结果,但需要返回一条的情况用GROUP_CONCAT拼接
查看>>
MySQL必知必会(组合Where子句,Not和In操作符)
查看>>
MySQL必知必会总结笔记
查看>>
MySQL快速入门
查看>>
MySQL快速入门——库的操作
查看>>
mysql快速复制一张表的内容,并添加新内容到另一张表中
查看>>
mysql快速查询表的结构和注释,字段等信息
查看>>