大数的减法函数--c语言
代码展示: 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语言的更多相关文章
- 大数的加法函数--c语言
浏览网站http://paste.ubuntu.com/23687758/ #include<stdio.h> #include<stdlib.h> #include<s ...
- 3204: 数组做函数参数--排序函数2--C语言
3204: 数组做函数参数--排序函数2--C语言 时间限制: 1 Sec 内存限制: 128 MB提交: 211 解决: 143[提交][状态][讨论版][命题人:smallgyy] 题目描述 ...
- 3203 数组做函数参数----排序函数--C语言版
3203: 数组做函数参数----排序函数--C语言版 时间限制: 1 Sec 内存限制: 128 MB提交: 253 解决: 151[提交][状态][讨论版][命题人:smallgyy] 题目描 ...
- <编译原理 - 函数绘图语言解释器(1)词法分析器 - python>
<编译原理 - 函数绘图语言解释器(1)词法分析器 - python> 背景 编译原理上机实现一个对函数绘图语言的解释器 - 用除C外的不同种语言实现 解释器分为三个实现块: 词法分析器: ...
- <编译原理 - 函数绘图语言解释器(2)语法分析器 - python>
<编译原理 - 函数绘图语言解释器(2)语法分析器 - python> 背景 编译原理上机实现一个对函数绘图语言的解释器 - 用除C外的不同种语言实现 设计思路: 设计函数绘图语言的文法, ...
- PHP:函数和语言结构(转)
转自:https://www.cnblogs.com/fanqiechaodan/articles/5222366.html 什么是语言结构呢?它和函数有什么不同吗? 1. 什么是语言结构和函数 语 ...
- <编译原理 - 函数绘图语言解释器(3)解释器 - python>
<编译原理 - 函数绘图语言解释器(3)解释器 - python> <编译原理 - 函数绘图语言解释器(2)词法分析器 - python> <编译原理 - 函数绘图语言解 ...
- 第四章 函数(JavaScript:语言精粹)
函数包含一组语句,用来指定对象的行为,其代码可以用来重复使用. 一般来说,编程就是将一组需求分解成一组函数和数据结构的技能. 概览:函数对象 | 函数字面量 | 调用 | 方法调用模式 | 函 ...
- Linux下普通IO文件操作函数---C语言
普通文件IO总结 FILE结构体 typedef struct { int level; /*填充/清空一级缓存*/ unsigned flag; /*文件状态指针*/ ...
随机推荐
- js数组遍历和对象遍历
针对js各种遍历作一个总结分析,从类型用处:分数组遍历和对象遍历:还有性能,优缺点等. JS数组遍历: 1,普通for循环,经常用的数组遍历 var arr = [1,2,0,3,9]; for ( ...
- ios-->制作ipa文件
用证书进行真机调试并生成二级制文件,通常位于:/Users/.../Library/Developer/Xcode/DerivedData/XXXXXDemo-gmtamkryoesxilartayu ...
- ios UIButton改背景
以下orangeButton.png与orangeButtonHighlight.png分别用于按钮平常状态和被点击时的状态: UIImage *buttonImage = [[UIImage ima ...
- The ways to kill Oracle session
As we all known ,its the normal way to use the SQL 'alter system kill 'sid,serial#'' to kill a ses ...
- macOS下加载动态库dylib报"code signature invalid"错误的解决办法
一.现象描述 在macOS上搞开发也有一段时间了,也积攒了一定的经验.然而,今天在替换工程中的一个动态库时还是碰到了一个问题.原来工程中用的是一个静态库,调试时发现有问题就把它替换成了动态库.这本来没 ...
- Loadrunner错误 -27727: 下载资源时步骤下载超时 (120 seconds) 已过期
由于压力大了,下载资源所用时间就长了,可以设置加大超时时间 运行时设置 Internet 协议--首选项--高级--选项 --General--步骤下载超时(秒) 把这个值从120改为更大,如300, ...
- JS正则密码复杂度校验之:至少有多种字符中的其中几种
概述 续接上文的密码校验要求: 这个需求有两个难点,一,是如何使用正则匹配所有半角英文标点符号,二,是如何验证密码段中在要求的四种(大写字母,小写字母,数字,标点符号)类型中至少存在三种. 第一个难点 ...
- 一步一步学多线程-ThreadLocal源码解析
上网查看了很多篇ThreadLocal的原理的博客,上来都是文字一大堆,费劲看了半天,大脑中也没有一个模型,想着要是能够有一张图明确表示出来ThreadLocal的设计该多好,所以就自己看了源码,画了 ...
- 剑指OFFER(百度笔试)——二叉树的子结构
百度软件开发实习生笔试: 1.模拟短作业优先调度算法,计算平均等待时间,例如输入[0,2,4,8]表示四个作业分别是第0s到.第2s到.第4s到.第8s到.[2,1,6,3]表示四个作业的运行时间. ...
- Android自定义控件系列之基础篇
一.概述 在android开发中很多UI控件往往需要进行定制以满足应用的需要或达到更加的效果,接下来就通过一个系列来介绍自定义控件,这里更多是通过一些案例逐步去学习,本系列有一些典型的应用,掌握好了大 ...