C++实现十六进制字符串转换为十进制整数的方法_C 语言

本文实例讲述了C++实现十六进制字符串转换为十进制整数的方法。分享给大家供大家参考。具体实现方法如下:

/*
* 将十六进制数字组成的字符串(包含可选的前缀0x或0X)转换为与之等价的整型值
*/
#include <stdio.h>
#include <math.h>
/* 将十六进制中的字符装换为对应的整数 */
int hexchtoi(char hexch )
{
 char phexch[] = "ABCDEF";
 char qhexch[] = "abcdef";
 int i;
 for(i=0;i<6;i++){
  if((hexch == phexch[i]) || (hexch == qhexch[i]))
   break;
 }
 printf("i=%d",i);
 if(i >= 6){
  return 0; /* 非十六进制字符 */
 }
 return 10+i;
}
int htoi(char s[])
{
 int n=0; /*有n位*/
 int valu=1; /*是否有效*/
 int i=0,j;
 int answer=0;
 /* 有效性检查 */
 if((s[0] == '0') && ((s[1] == 'x') || (s[1] == 'X'))){
  i += 2;
 }
 while((s[i] != '\n')){
  if((s[i] < '0') && (s[i] > '9')){
   if(hexchtoi(s[i]) == 0){
    valu=0;
    break;
   }
  }
  n++;
  i++;
 }
 if(valu != 0){
  for(j=0;j<n;j++){
   answer += ((int)pow(16,j) * hexchtoi(s[i-j-1]));
  }
 }
 else
  answer = -1;
 return answer;
}
main()
{
 char *n[] = {"0x7ff0","0x2341"};
 printf("%s is %d\n",n[0],htoi(n[0]));
 printf("%s is %d\n",n[0],123);
}

希望本文所述对大家的C++程序设计有所帮助。

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索c++
, 字符串
, 十六进制
, 转换
, 十进制
整数
十六进制字符串转整数、c语言 十六进制字符串、十六进制整数、十六进制整数 0x12fd2、java 整数转十六进制,以便于您获取更多的相关知识。

时间: 2024-12-10 19:42:57

C++实现十六进制字符串转换为十进制整数的方法_C 语言的相关文章

将一个十六进制字符串转换为十进制数值的问题

在程序中,我们有时需要将一个十六进制字符串转换为十进制数字.比如:char *ptr="0x11";int n=0;//我们想让n等于0x11,即17 通常我们在C中,想将一个字符串转换为一整形数字,通常会使用下面的方法:   char *ptr="123";       int n=0;   n=atoi(ptr);   printf("%d/n",n);   //输出:123     但是atoi库函数只能将十进制字符串转化为int整形,比如

C语言中一些将字符串转换为数字的函数小结_C 语言

C语言atoi()函数:将字符串转换成int(整数)头文件: #include <stdlib.h> atoi() 函数用来将字符串转换成整数(int),其原型为: int atoi (const char * str); [函数说明]atoi() 函数会扫描参数 str 字符串,跳过前面的空白字符(例如空格,tab缩进等,可以通过 isspace() 函数来检测),直到遇上数字或正负符号才开始做转换,而再遇到非数字或字符串结束时('\0')才结束转换,并将结果返回. [返回值]返回转换后的整

c语言中字符串分割函数及实现方法_C 语言

1.问题引入 自己在写一个linux下的模拟执行指令的时候,遇到了输入"cat a.c",要将该字符串分解成cat和a.c两个单独的字符串,虽然知道有strtok的存在,但是想自己尝试写一下,于是就自己写了一个,不过总是遇到这样或那样的问题,虽然最后调通了,不过确浪费了不少时间:后来作业交上去以后又仔细阅读了strtok函数,发现原来linux下已经改成strsep,所有在这里就写一下自己所走的过程. 2.自己写的字符串分割函数:用于分割指令,比如cat a.c最后会被分割成cat和a

C语言左旋转字符串与翻转字符串中单词顺序的方法_C 语言

左旋转字符串题目: 定义字符串的左旋转操作:把字符串前面的若干个字符移动到字符串的尾部. 如把字符串 abcdef  左旋转 2  位得到字符串 cdefab.请实现字符串左旋转的函数. 要求时间对长度为 n  的字符串操作的复杂度为 O(n),辅助内存为 O(1). 分析: 网上看到解法很多种,就不详细说明了. 我采用的是数组不对称的交换时间复杂度应该是O(n). 代码实现(GCC编译通过): #include "stdio.h" #include "stdlib.h&qu

C语言实现返回字符串函数的四种方法_C 语言

前言 C语言返回字符串函数共有四种方式,分别如下:       使用堆空间,返回申请的堆地址,注意释放       函数参数传递指针,返回该指针       返回函数内定义的静态变量(共享)       返回全局变量 下面来看看详细的介绍 其实就是要返回一个有效的指针,尾部变量退出后就无效了. 使用分配的内存,地址是有效 char *fun() { char* s = (char*)calloc(100, sizeof(char*) ); if (s) strcpy ( s , "abc &qu

C语言中交换int型变量的值及转换为字符数组的方法_C 语言

不使用其他变量交换两个整型的值: #include <stdio.h> void main(){ int a = 3; int b = 4; a = a ^ b;//使用异或交换 b = b ^ a; a = a ^ b; printf("%d, %d\n", a, b); a = a - b;//使用加减交换 b = a + b; a = b - a; printf("%d, %d\n", a, b); a ^= b ^= a ^= b; printf

c语言中十六进制转二进制显示的实现方法_C 语言

复制代码 代码如下: //====================================== //输出格式: hex2bin 5e. //得到: 0101 1110 //====================================== #include <stdio.h>#include <limits.h> char *bitstr(char *, void const *, size_t); int main(int argc, char **argv){

深入C语言把文件读入字符串以及将字符串写入文件的解决方法_C 语言

1.纯C实现 复制代码 代码如下:  FILE *fp; if ((fp = fopen("example.txt", "rb")) == NULL) {  exit(0); } fseek(fp, 0, SEEK_END); int fileLen = ftell(fp); char *tmp = (char *) malloc(sizeof(char) * fileLen); fseek(fp, 0, SEEK_SET); fread(tmp, fileLen,

使用JavaScript进行进制转换将字符串转换为十进制

JS 是一个很神奇的语言,内制的的很多函数可以帮我们进行数(进)制转换: JS中可以直接使用16进制: var a = 0xff; //255 将任意进制字符串转换为十进制,如二进制,八进制,十六进制, 第二数数不写即为最常用的转换为整型十进制:   代码如下: parseInt("11", 2); // 3 2进制转10进制 parseInt("77", 8); // 63 8进制转10进制 parseInt("af", 16); //175