实验7-3-6 字符串转换成十进制整数

题目

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

输入格式及样例

格式

输入在一行中给出一个以#结束的非空字符串。

样例

输出格式及样例

格式

在一行中输出转换后的十进制数。题目保证输出在长整型范围内。

样例

在这里插入图片描述

参考代码

#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
#include<math.h>
int main() {
	char* arr = (char*)malloc(sizeof(char));
	int n = 0;
	for (int i = 0;; i++) {
		scanf("%c", &arr[i]);
		n++;
		if (arr[i] == '#')
			break;
	}
	int* brr = (int*)malloc(sizeof(int) * n);
	int tick = 1;
	int flag = 1;
	int k = 0;
	for (int i = 0; i < n; i++) {
		if (arr[i] == '-'&&flag)
			tick = 0;
		if ((arr[i]>='0'&&arr[i]<='9')||(arr[i] >= 'A' && arr[i] <= 'F') || (arr[i] >= 'a' && arr[i] <= 'f'))
		{
			flag = 0;
			//printf("brr----%c\n", brr[i]);
			if (arr[i] >= 'a' && arr[i] <= 'f') {
				brr[k] = arr[i] - 'a' + 10;
				//printf("brr[%d]=%d\n", k, brr[k]);
				k++;
			}
			else if (arr[i] >= 'A' && arr[i] <= 'F') {
				brr[k] = arr[i] - 'A' + 10;
				//printf("brr[%d]=%d\n", k, brr[k]);
				k++;
			}
			else {
				brr[k] = arr[i] - '0';
				//printf("brr[%d]=%d\n", k, brr[k]);
				k++;
			}
		}
	}
	int result = 0;
	for (int i = 0; i < k; i++) {
		//printf("c:%d\n", brr[i]);
		int p = k - i - 1;
		result = result + brr[i] * pow(16, p);
	}
	if (!tick)
		result = result * (-1);
	printf("%d", result);
	return 0;
}

版权声明:本文为qq_45823731原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。