Преобразование строки в целое число на языке 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, произойдет переполнение.