博客
关于我
十六进制用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实现finding bridges寻找桥梁算法(附完整源码)
查看>>
Objective-C实现first come first served先到先得算法(附完整源码)
查看>>
Objective-C实现FIR滤波器(附完整源码)
查看>>
Objective-C实现fischer yates shuffle洗牌算法(附完整源码)
查看>>
Objective-C实现FisherYates Shuffle洗牌算法(附完整源码)
查看>>
Objective-C实现fisherYates洗牌算法(附完整源码)
查看>>
Objective-C实现FloodFill洪水填充函数算法(附完整源码)
查看>>
Objective-C实现Floyd-Warshall算法(附完整源码)
查看>>
Objective-C实现FPmax算法(附完整源码)
查看>>
Objective-C实现frequency finder频率探测器算法(附完整源码)
查看>>
Objective-C实现FTP上传文件(附完整源码)
查看>>
Objective-C实现FTP文件上传(附完整源码)
查看>>
Objective-C实现FTP文件下载(附完整源码)
查看>>
Objective-C实现fuzzy operations模糊运算算法(附完整源码)
查看>>
Objective-C实现Gale-Shapley盖尔-沙普利算法(附完整源码)
查看>>
Objective-C实现gamma recursive伽玛递归算法(附完整源码)
查看>>
Objective-C实现gamma 伽玛功能算法(附完整源码)
查看>>
Objective-C实现gauss easte高斯复活节日期算法(附完整源码)
查看>>
Objective-C实现gaussian filter高斯滤波器算法(附完整源码)
查看>>
Objective-C实现gaussian naive bayes高斯贝叶斯算法(附完整源码)
查看>>