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

你可能感兴趣的文章
Objective-C实现求a的逆元x(附完整源码)
查看>>
Objective-C实现求两点间距离(附完整源码)
查看>>
Objective-C实现求众数(附完整源码)
查看>>
Objective-C实现求曲线在某点的导数(附完整源码)
查看>>
Objective-C实现求最大公约数 (GCD)的算法(附完整源码)
查看>>
Objective-C实现求模逆算法(附完整源码)
查看>>
Objective-C实现汉密尔顿循环算法(附完整源码)
查看>>
Objective-C实现洗牌移位密码算法(附完整源码)
查看>>
Objective-C实现测试信用卡号码有效性credit card validator的算法(附完整源码)
查看>>
Objective-C实现深度优先搜索递归算法(附完整源码)
查看>>
Objective-C实现混沌算法(附完整源码)
查看>>
Objective-C实现滑动平均滤波(附完整源码)
查看>>
Objective-C实现牛顿下山法(附完整源码)
查看>>
Objective-C实现牛顿插值法(附完整源码)
查看>>
Objective-C实现牛顿法算法(附完整源码)
查看>>
Objective-C实现状态模式(附完整源码)
查看>>
Objective-C实现狄克斯特拉算法(附完整源码)
查看>>
Objective-C实现猜数字算法(附完整源码)
查看>>
Objective-C实现猴子爬山算法(附完整源码)
查看>>
Objective-C实现生产者和消费者问题(附完整源码)
查看>>