A除于B(大数相除)

简介: A除于B(大数相除)

A除以B

题目描述:

本题要求计算 A/B,其中 A 是不超过 1000 位的正整数,B 是 1 位正整数。你需要输出商数 Q 和余数 R,使得 A=B×Q+R 成立。

输入格式:

输入在一行中依次给出 A 和 B,中间以 1 空格分隔。

输出格式:

在一行中依次输出 Q 和 R,中间以 1 空格分隔。

输入样例:

 

123456789050987654321 7

输出样例:

 

17636684150141093474 3

题目来源:PAT乙级1017

作者:CHEN, Yue

单位:浙江大学

分析:

       此题中的被除数A为不超过1000位的整数,从这句话可知用常规的整型数据类型无法存储这么大的数,所以我们应该使用字符串对大数进行处理,我们可以先分析自己在进行除法运算时的步骤,主要有以下几个特点:

1、从最高位开始除

2、相除的整数解记到相应的位数上,余数需与下一位数合并后再继续计算

代码如下:

#include<stdio.h>
#include<string.h>
int main()
{
  char a[1005];
  int b;
  while(scanf("%s %d",a,&b)!=EOF){
    int ans[1005],n=0,i=0,temp=0;
    for(i=0;i<strlen(a);i++){
      ans[n]=(a[i]-'0'+temp*10)/b;//除得整数 
      temp = (a[i]-'0'+temp*10)%b;//除得余数 
      if(ans[n]>0||i>0) n++; //结果位数加一
    }
    for(i=0;i<n;i++)
      printf("%d",ans[i]);
    printf(" ");
    printf("%d\n",temp);  
  } 
return 0;
} 
目录
相关文章
|
8月前
PAT乙级 1017大数除法
PAT乙级 1017大数除法
|
9月前
大整数的因子(利用求余)
大整数的因子(利用求余)
大数的四则运算(加,减,乘,除)处理
大数的四则运算(加,减,乘,除)处理
661 0
大数的四则运算(加,减,乘,除)处理
7-41 大数的乘法 (10 分)
7-41 大数的乘法 (10 分)
85 0
求一个数n次方后的末尾数(数论/快速幂)
hdu1061-Rightmost Digit hdu1097-A hard puzzle 这两个oj题目思路几乎一样,都是为了快速求出一个数n次方后的末尾数为都多少?
261 0
求一个数n次方后的末尾数(数论/快速幂)
算法零基础——大数四则运算
算法零基础——大数四则运算
算法零基础——大数四则运算
大整数相乘(分治)
参考了(感谢):http://blog.csdn.net/jeffleo/article/details/53446095 继续变换:XY=AC2^n+[(A-B)(D-C)+AC+BD]2^n/2+BD 把原来的A...
876 0
|
存储 人工智能 PHP