博客
关于我
十六进制用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/

你可能感兴趣的文章
mysqldump备份时忽略某些表
查看>>
mysqlreport分析工具详解
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>
MySQL万字总结!超详细!
查看>>
mysql中cast() 和convert()的用法讲解
查看>>
MySQL中group by 与 order by 一起使用排序问题
查看>>
mysql中having的用法
查看>>
mysql中json_extract的使用方法
查看>>
MySQL中的DECIMAL类型:MYSQL_TYPE_DECIMAL与MYSQL_TYPE_NEWDECIMAL详解
查看>>
MySQL中的GROUP_CONCAT()函数详解与实战应用
查看>>
MySQL中的ON DUPLICATE KEY UPDATE详解与应用
查看>>
mysql中的undo log、redo log 、binlog大致概要
查看>>
MySQL主从篇:死磕主从复制中数据同步原理与优化
查看>>
Mysql事务。开启事务、脏读、不可重复读、幻读、隔离级别
查看>>
MySQL事务原理以及MVCC详解
查看>>
mysql事务理解
查看>>
MySQL事务隔离级别:读未提交、读已提交、可重复读和串行
查看>>
MySQL什么情况下会导致索引失效
查看>>
MySQL修改密码报错ERROR 1396 (HY000): Operation ALTER USER failed for ‘root‘@‘localhost‘
查看>>