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

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

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

以下是实现这一功能的C语言程序:

#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++; } } } for (i = 0; i < wei; i++) { if (a[i] == '-') { for (j = k - 1; j >= 0; j--) { b[j + 1] = b[j]; } b[0] = '-'; k++; break; } } printf("%ld", strtol(b, &end, 16));}

这个程序首先读取输入字符串a,然后遍历每个字符,检查它是否是十六进制字符(包括字母和数字)。如果是,就将其添加到数组b中。同时记录第一个十六进制字符的位置wei,以便后续处理负数的情况。

在处理负数时,如果发现第一个十六进制字符之前存在“-”,则将b数组中的字符左移,插入“-”到前面,并增加k的值。

最后,使用strtol函数将十六进制字符串b转换为十进制数并输出结果。

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

你可能感兴趣的文章
TCP基本入门-简单认识一下什么是TCP
查看>>
tableviewcell 中使用autolayout自适应高度
查看>>
Orcale表被锁
查看>>
svn访问报错500
查看>>
org.apache.ibatis.exceptions.TooManyResultsException: Expected one result (or null) to be returned
查看>>
org.apache.ibatis.type.TypeException: Could not resolve type alias 'xxxx'异常
查看>>
org.apache.poi.hssf.util.Region
查看>>
org.apache.xmlbeans.XmlOptions.setEntityExpansionLimit(I)Lorg/apache/xmlbeans/XmlOptions;
查看>>
org.apache.zookeeper.KeeperException$ConnectionLossException: KeeperErrorCode = ConnectionLoss for /
查看>>
org.hibernate.HibernateException: Unable to get the default Bean Validation factory
查看>>
org.hibernate.ObjectNotFoundException: No row with the given identifier exists:
查看>>
org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
查看>>
org.springframework.orm.hibernate3.support.OpenSessionInViewFilter
查看>>
org.springframework.web.multipart.MaxUploadSizeExceededException: Maximum upload size exceeded
查看>>
org.tinygroup.serviceprocessor-服务处理器
查看>>
org/eclipse/jetty/server/Connector : Unsupported major.minor version 52.0
查看>>
org/hibernate/validator/internal/engine
查看>>
SQL-36 创建一个actor_name表,将actor表中的所有first_name以及last_name导入改表。
查看>>
ORM sqlachemy学习
查看>>
Ormlite数据库
查看>>