在字串中提取首個整數並區分正負

2020-10-20 14:00:24

在字串中提取首個整數並區分正負

// 字串轉數值.cpp: 定義控制檯應用程式的入口點。
//

#include "stdafx.h"
#include"conio.h"
int convert(char* arr)
{
	int i, j, k;
	int m = 0;//用於記錄數位的真實位數
	int n = 0;//用於記錄需要輸出的數位從字串的第幾位開始記錄位數
	int F = 0;
	int  A, count = 0, B = 0;
	while (arr[count] != '\0')//用於計算字串的位數
		count++;
	//printf("count is %d\n", count);
	for (i = 0; i < count; i++)
	{
		if ((int)arr[i] == 45 && (int)arr[i + 1] > 47 && (int)arr[i + 1] < 58)//判斷這個數是否為負數並標記
		{
			n++;
			F = 1;
			continue;
		}
		if ((int)arr[i] < 48 || (int)arr[i]>57)//記錄需要輸出的數位從第幾位開始
		{
			n++;
			continue;
		}
		if ((int)arr[i] > 47 && (int)arr[i] < 58 && (int)arr[i + 1] > 47 && (int)arr[i + 1] < 58)//記錄需要輸出的數位的位數
			m++;
		if ((int)arr[i] > 47 && (int)arr[i] < 58 && ((int)arr[i + 1] < 48 || (int)arr[i + 1]>57))//記錄需要輸出的數位的位數並標記需要輸出的數位是否即將結束
		{
			m++;
			break;
		}
	}
	//printf("%d\n", n);
	//printf("%d\n", F);
	//printf("%d\n", m);
	k = m - 2;
	for (i = n; i < n + m; i++)//利用n與n+m確定在陣列的哪裡開始檢索需要輸出數位,在哪裡結束。
	{
		A = 1;
		if (i != n + m - 1)
		{
			for (j = k; j >= 0; j--)
				A *= 10;
			//printf("%d\n", A);
			B += A * ((int)arr[i] - 48);
		}
		else
			B += A * ((int)arr[i] - 48);
		k--;
	}
	if (F == 1)
		return -B;
	return B;
}
int main()
{
	char arr[] = "***-012-345";
	printf("%d\n", convert(arr));
	_getch();
	return 0;
}