代码展示:   http://paste.ubuntu.com/23693598/

#include<stdio.h>

#include<stdlib.h>

#include<string.h>

char * largeDiffer(char *a,char *b){

/*  使用说明

传入的a和b只能为整数

结果为a-b;返回的为字符指针,注意数组不要越界 ,要加头文件string.h

*/

int a_num[1000]={0},b_num[1000]={0};

char result[1000];//返回的结果

int a_len,b_len,i,j,cmp=-1,len,differ;

a_len=strlen(a);//计算a,b的长度

b_len=strlen(b);

for(i=0;i<a_len;i++){

a_num[a_len-i-1]=a[i]-'0';//给a倒叙赋值

}

for(i=0;i<b_len;i++){

b_num[b_len-i-1]=b[i]-'0';//给a倒叙赋值

}

if(a_len>b_len) cmp=1;//a大于b返回1    否则,返回-1

else if(a_len<b_len) cmp=-1;

else cmp=strcmp(a,b);

len=a_len>b_len?a_len:b_len;//返回较大值

if(cmp==1){//a为     大数的时候

for(i=0;i<len;i++){

if(a_num[i]<b_num[i]){

a_num[i]+=10;

if(a_num[i]<0){

a_num[i]=9;

a_num[i+1]=a_num[i+1]-1;

}

a_num[i+1]=a_num[i+1]-1;

differ=a_num[i]-b_num[i];

a_num[i]=differ;

}else{

differ=a_num[i]-b_num[i];

a_num[i]=differ;

}

}

} else if(cmp==-1){//第一个输入的为小数的时候

for(i=0;i<len;i++){

if(b_num[i]<a_num[i]){

b_num[i]+=10;

if(b_num[i]<0){

b_num[i]=9;

b_num[i+1]=b_num[i+1]-1;

}

b_num[i+1]=b_num[i+1]-1;

differ=b_num[i]-a_num[i];

a_num[i]=differ;//

}else{

differ=b_num[i]-a_num[i];

a_num[i]=differ;//

}

}

}

//输出格式

i=len-1;

while(a_num[i]==0) i--;//直到第一个不为0的数

if(cmp==-1) {

result[0]='-';

for(j=1;i>=0;i--,j++)

result[j]=a_num[i]+'0';

result[j]='\0';

} else{

for(j=0;i>=0;i--,j++)

result[j]=a_num[i]+'0';

result[j]='\0';

}

return result;

}

int main(){

char a[1000],b[1000];

gets(a);

gets(b);

char result[1000];

strcpy(result,largeDiffer(a,b));

printf("%s",result);

}

编程爱好者 248351598

大数的减法函数--c语言的更多相关文章

  1. 大数的加法函数--c语言

    浏览网站http://paste.ubuntu.com/23687758/ #include<stdio.h> #include<stdlib.h> #include<s ...

  2. 3204: 数组做函数参数--排序函数2--C语言

    3204: 数组做函数参数--排序函数2--C语言 时间限制: 1 Sec  内存限制: 128 MB提交: 211  解决: 143[提交][状态][讨论版][命题人:smallgyy] 题目描述 ...

  3. 3203 数组做函数参数----排序函数--C语言版

    3203: 数组做函数参数----排序函数--C语言版 时间限制: 1 Sec  内存限制: 128 MB提交: 253  解决: 151[提交][状态][讨论版][命题人:smallgyy] 题目描 ...

  4. <编译原理 - 函数绘图语言解释器(1)词法分析器 - python>

    <编译原理 - 函数绘图语言解释器(1)词法分析器 - python> 背景 编译原理上机实现一个对函数绘图语言的解释器 - 用除C外的不同种语言实现 解释器分为三个实现块: 词法分析器: ...

  5. <编译原理 - 函数绘图语言解释器(2)语法分析器 - python>

    <编译原理 - 函数绘图语言解释器(2)语法分析器 - python> 背景 编译原理上机实现一个对函数绘图语言的解释器 - 用除C外的不同种语言实现 设计思路: 设计函数绘图语言的文法, ...

  6. PHP:函数和语言结构(转)

    转自:https://www.cnblogs.com/fanqiechaodan/articles/5222366.html 什么是语言结构呢?它和函数有什么不同吗? 1.  什么是语言结构和函数 语 ...

  7. <编译原理 - 函数绘图语言解释器(3)解释器 - python>

    <编译原理 - 函数绘图语言解释器(3)解释器 - python> <编译原理 - 函数绘图语言解释器(2)词法分析器 - python> <编译原理 - 函数绘图语言解 ...

  8. 第四章 函数(JavaScript:语言精粹)

    函数包含一组语句,用来指定对象的行为,其代码可以用来重复使用.   一般来说,编程就是将一组需求分解成一组函数和数据结构的技能.   概览:函数对象 | 函数字面量 | 调用 | 方法调用模式 | 函 ...

  9. Linux下普通IO文件操作函数---C语言

    普通文件IO总结 FILE结构体    typedef struct   {       int level; /*填充/清空一级缓存*/     unsigned flag; /*文件状态指针*/ ...

随机推荐

  1. 超强、超详细Redis数据库入门教程(转载)

    这篇文章主要介绍了超强.超详细Redis入门教程,本文详细介绍了Redis数据库各个方面的知识,需要的朋友可以参考下   [本教程目录] 1.redis是什么 2.redis的作者何许人也 3.谁在使 ...

  2. 点击文字选中radio

    <html><body><form action="" name="form1" method="post"& ...

  3. HDU 6006 Engineer Assignment:状压dp

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6006 题意: 在Google中,有个n项目,m个专家.第i个项目涉及c[i]个领域,分别为a[i][0 ...

  4. java修饰符public final static abstract transient

    JAVA 修饰符public final static abstract transient  关键字: public final static abstract ...  1.public prot ...

  5. MarkdownPad2之安装破解

    MarkdownPad2之安装破解 一.下载破解版 1.地址链接:http://pan.baidu.com/s/1i5JzG13 密码: 4jgw 2.按步骤安装后,进行汉化:[Tool]--> ...

  6. AugularJS1.X不升级到2.X

    面试中提到AugularJS1.X不升级到2.X,而是改用React的原因是,可以利用很多React现成的组件,需要确认下 以及提到了Vue, Weex技术

  7. vue-cli脚手架npm相关文件解读(6)build.js

    系列文章传送门: 1.build/webpack.base.conf.js 2.build/webpack.prod.conf.js 3.build/webpack.dev.conf.js 4.bui ...

  8. 面试题1 -- Java 中,怎么在格式化的日期中显示时区?

    使用SimpleDateFormat来实现格式化日期 import java.text.SimpleDateFormat; import java.util.Date; public class Da ...

  9. archlinux系统安装博通B43XX系列无线网卡驱动

    我的无线网卡是博通的B43xx系列,大家都知道博通对于其Wifi卡在 GNU/Linux 上的支持不好可谓是臭名昭著. 用 lspci -vnn -d 14e4: 或者 lspci -vnn | gr ...

  10. Struts2拦截器配置实例

    拦截器介绍 拦截器 的使用 ,源自Spring AOP(面向切面编程)思想 拦截器 采用 责任链 模式 * 在责任链模式里,很多对象由每一个对象对其下家的引用而连接起来形成一条链. * 责任链每一个节 ...