Преобразование строки в целое число на языке C

Требовать

1. Во вход включены только положительные и отрицательные знаки и числа.
2. Знак плюс или минус появляется только в первую очередь.

учиться

(1) Отрицательный код Ascii равен 45, а положительный код Ascii равен 43.
(2) Преобразование между символами типа char и целочисленными типами необходимо сократить на 48. Например, если char a='6' преобразовать в тип int, это будет
продемонстрировано как int b=a-48.
(3) Если первый бит является символом, запишите его с флагом и, наконец, внесите соответствующие изменения.

#include<stdio.h>
int main(){
    
    
	char a='6';
	int b=a-48;
	printf("%d",b);
	return 0;
}

выходной результат
вставьте сюда описание изображения

Основная идея

1. Сначала просмотрите строку s, преобразуйте каждый символ в число, сохраните его в массиве целых чисел a и запишите конечный индекс a.
2. Пройдите массив целых чисел a, умножьте каждый элемент на соответствующий порядок величины и сложите их.
вставьте сюда описание изображения

Как умножить на соответствующий порядок величины, поскольку целочисленный массив a проходится от i=0, каждый элемент умножается на первую степень i числа 10.
предполагается следующим образом.
вставьте сюда описание изображения

обход при суммировании.
вставьте сюда описание изображения

код

Найдите энную степенную функцию числа 10.

//10的n次方 
int g(int n){
    
    
	int t=1;
	int i;
	if(n==0){
    
    //10的0次方等于1
		return 1;
	} else{
    
    
		for(i=0;i<n;i++){
    
    
			t=t*10;
		}
	}
	return t;
}

Преобразовать строку s в целочисленную функцию

int f(char* s){
    
    
	int a[100];
	int top=-1;
	int i;
	int flag=0;//如果第一位是符号,则用flag记录 
	int sum=0;//记录最后的返回值 
	
	for(i=0;s[i]!='\0';i++){
    
    //遍历字符串s 
		if(s[i]=='-'||s[i]=='+'){
    
    //如果是符号则放入flag中 
			flag=s[0];
		}else{
    
    
			top++;
			a[top]=s[i]-48; //字符转整型减48 
		}
	}
	
	for(int i=0;i<=top;i++){
    
    //遍历整型数组a 
		sum=sum+a[i]*g(top-i);//每一项乘以对应的数量级 
		
	}
	
	if(flag==45){
    
    //判断符号 
		return -1*sum;
	}else{
    
    
		return sum;
	}
	
} 

все коды

#include<stdio.h>

//10的n次方 
int g(int n){
    
    
	int t=1;
	int i;
	if(n==0){
    
    
		return 1;
	} else{
    
    
		for(i=0;i<n;i++){
    
    
			t=t*10;
		}
	}
	return t;
}

int f(char* s){
    
    
	int a[100];
	int top=-1;
	int i;
	int flag=0;//如果第一位是符号,则用flag记录 
	int sum=0;//记录最后的返回值 
	
	for(i=0;s[i]!='\0';i++){
    
    //遍历字符串s 
		if(s[i]=='-'||s[i]=='+'){
    
    //如果是符号则放入flag中 
			flag=s[0];
		}else{
    
    
			top++;
			a[top]=s[i]-48; //字符转整型减48 
		}
		
	}
	
	
	
	for(int i=0;i<=top;i++){
    
    //遍历整型数组a 
		sum=sum+a[i]*g(top-i);//每一项乘以对应的数量级 
		
	}
	
	if(flag==45){
    
    //判断符号 
		return -1*sum;
	}else{
    
    
		return sum;
	}
	
	
} 


int main(){
    
    
	char s[100];
	scanf("%s",s);
	int a=f(s);
	printf("%d",a);
} 

недостаточный

Если массив целых чисел, представленный строкой, превышает диапазон, который может хранить int, произойдет переполнение.

Ich denke du magst

Origin blog.csdn.net/baiqi123456/article/details/123786981
Empfohlen
Rangfolge