解题思路:
注意事项:
参考代码:
#include<stdio.h>
#include <string.h>
void change(char n[],int m){ //将数字字符逆序
int i,j;
char t;
i=0;
j=m-1;
while (i<=j){
t=n[i];
n[i]=n[j];
n[j]=t;
i++;
j--;
}
}
int main(){
char a[1000];
char b[1000];
int x[1000]={0}; //全部数字数组都赋值0,以便后面计算!!!
int y[1000]={0};
int z[1000]={0};
int len_a,len_b;
scanf ("%s",a); //要用scanf才会对哦!!!,gets是过不了的
scanf ("%s",b);
len_a=strlen(a);
len_b=strlen(b);
change(a,len_a); //逆序a
change(b,len_b); //逆序b
for (int i=0;a[i]!='\0';i++){ //字符转换成数字
x[i]=a[i]-'0';
}
for (int i=0;b[i]!='\0';i++){ //字符转换成数字
y[i]=b[i]-'0';
}
for (int i=0;a[i]!='\0';i++){ //减法开始
z[i]=x[i]-y[i];
}
for (int i=0;i<len_a;i++){ //处理借位,如果数字数组小于0,向前借位即可
if (z[i]<0){
z[i]+=10;
z[i+1]--;
}
}
int n;
for (int i=len_a;i>=0;i--){ //删去前导零
if (z[i]>0){ //找到不是零的,即最高位,跳出循环
n=i;
break;
}
if (i==0){ //如果一直到最后一位都是0,则输出零即可
printf ("0");
return 0;
}
}
for (int i=n;i>=0;i--){ //输出即可
printf ("%d",z[i]);
}
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复