C言語での文字列から整数への変換
必要とする
1.正と負の符号と数字のみが入力に含まれます。
2.プラスまたはマイナス記号は最初にのみ表示されます。
学び
(1)負のASCIIコードは45で、正のASCIIコードは43です。
(2)char型文字とinteger型の変換は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のn乗関数を見つけます
//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が格納できる範囲を超えると、オーバーフローが発生します。