博客
关于我
十六进制用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实现BP误差逆传播算法(附完整源码)
查看>>
Objective-C实现breadth First Search广度优先搜索算法(附完整源码))
查看>>
Objective-C实现BreadthFirstSearch广度优先搜索算法(附完整源码)
查看>>
Objective-C实现BreadthFirstShortestPath广度优先最短路径算法(附完整源码)
查看>>
Objective-C实现bubble sort冒泡排序算法(附完整源码)
查看>>
Objective-C实现bucket sort桶排序算法(附完整源码)
查看>>
Objective-C实现Burke 抖动算法(附完整源码)
查看>>
Objective-C实现Burrows-Wheeler 算法(附完整源码)
查看>>
Objective-C实现CaesarsCiphe凯撒密码算法(附完整源码)
查看>>
Objective-C实现calloc函数功能(附完整源码)
查看>>
Objective-C实现canny边缘检测算法(附完整源码)
查看>>
Objective-C实现cartesianProduct笛卡尔乘积算法(附完整源码)
查看>>
Objective-C实现check strong password检查密码强度算法(附完整源码)
查看>>
Objective-C实现chudnovsky algorithm楚德诺夫斯基算法(附完整源码)
查看>>
Objective-C实现CIC滤波器(附完整源码)
查看>>
Objective-C实现circle sort圆形排序算法(附完整源码)
查看>>
Objective-C实现CircularQueue循环队列算法(附完整源码)
查看>>
Objective-C实现clearBit清除位算法(附完整源码)
查看>>
Objective-C实现climbStairs爬楼梯问题算法(附完整源码)
查看>>
Objective-C实现cocktail shaker sort鸡尾酒排序算法(附完整源码)
查看>>