鱼C论坛

 找回密码
 立即注册
查看: 4637|回复: 15

[已解决]用c语言1000位整数的除法

[复制链接]
发表于 2019-2-26 17:21:56 | 显示全部楼层 |阅读模式
9鱼币
本题要求计算 A/B,其中 A 是不超过 1000 位的正整数,B 是 1 位正整数。你需要输出商数 Q 和余数 R,使得 A=B×Q+R 成立。
输入格式:
输入在一行中依次给出 A 和 B,中间以 1 空格分隔。
输出格式:
在一行中依次输出 Q 和 R,中间以 1 空格分隔。

请问哪里错误了!!!
  1. #include<stdio.h>
  2. #include<string.h>
  3. int main() {
  4.         int num[1000];        //存放被除数
  5.         int q[1000];        //存放商
  6.         int r, lenth=0;        //余数,被除数的位数
  7.         char c;       
  8.         int b,sign=0;        //除数 ,空格标识符       
  9.         while ((c=getchar())!='\n') {        //存储被除数跟除数
  10.                 if (sign == 0&&c!=' ') {        //存储被除数
  11.                         num[lenth] = c - '0';
  12.                         lenth++;
  13.                 }
  14.                 if(sign==1){        //存储除数
  15.                                 b = c - '0';
  16.                 }
  17.                 if (c == ' ') {//遇到空格sign为1;
  18.                         sign = 1;
  19.                 }
  20.         }
  21.         int diff = 0;        //除法中每一次的被除数
  22.         int qi = 0,ni=0;        //商,被除数中的数组坐标
  23.         for (int i = 0; i < lenth; i++) {               
  24.                         diff = diff * 10 + num[ni];       
  25.                         if (diff < b&&i==0) {        //被除数的第一位数小于除数,向后借位,坐标加一
  26.                                 ni++;
  27.                                 diff = diff * 10 + num[ni];
  28.                                 lenth = lenth - 1;
  29.                         }       
  30.                         ni++;
  31.                         q[qi] = diff / b;                       
  32.                         diff = diff%b;                       
  33.                         qi++;                       
  34.                         if (i == lenth - 1) {        //最后一次做除法的余数为整个除法的余数
  35.                                 r = diff;
  36.                         }
  37.         }
  38.         for (int i = 0; i < qi; i++) {
  39.                 printf("%d",q[i]);
  40.         }
  41.         printf(" %d\n",r);
  42.         return 0;
  43. }
复制代码

最佳答案
2019-2-26 17:21:57
本帖最后由 行客 于 2019-2-28 11:07 编辑

这个应该还是算法上的问题,感觉你的算法不是很好理解。

比如,你的代码输入“0 1”做测试,结果就会出现问题。

你是就想在这个代码里找出错误,还是随便改代码啊?
1017结果.PNG

最佳答案

查看完整内容

这个应该还是算法上的问题,感觉你的算法不是很好理解。 比如,你的代码输入“0 1”做测试,结果就会出现问题。 你是就想在这个代码里找出错误,还是随便改代码啊?

评分

参与人数 1荣誉 +5 鱼币 +1 贡献 +3 收起 理由
DT_Nelson + 5 + 1 + 3 鱼C有你更精彩^_^

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-2-26 17:21:57 | 显示全部楼层    本楼为最佳答案   
本帖最后由 行客 于 2019-2-28 11:07 编辑

这个应该还是算法上的问题,感觉你的算法不是很好理解。

比如,你的代码输入“0 1”做测试,结果就会出现问题。

你是就想在这个代码里找出错误,还是随便改代码啊?
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-2-26 19:56:41 | 显示全部楼层
本帖最后由 910201513 于 2019-2-26 20:10 编辑

呃,智障了,看成了1000,原来是1000位
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-2-26 20:49:09 | 显示全部楼层
那个错误的测试点是啥能告知吗?我细细捋了一下,没有发现啥错误啊
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2019-2-26 20:56:23 | 显示全部楼层
910201513 发表于 2019-2-26 20:49
那个错误的测试点是啥能告知吗?我细细捋了一下,没有发现啥错误啊

没有  我也不知道是哪里的   测试结果就给了上面的图
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-2-26 22:30:31 | 显示全部楼层
@行客
大佬,求教
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-2-27 09:14:59 From FishC Mobile | 显示全部楼层
大佬!题都有点没读懂!
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-2-27 11:23:00 From FishC Mobile | 显示全部楼层
ALifeTime 发表于 2019-2-27 09:14
大佬!题都有点没读懂!

就是A/B,求商和余,输入A(不大于1000位的正整数),B(一位正整数),你设计程序输出商和余
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-2-27 16:07:00 | 显示全部楼层
910201513 发表于 2019-2-26 22:30
@行客
大佬,求教

没有看出错误。在线测试代码也并未提示错误:
https://www.nowcoder.com/pat/6/problem/4043
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-2-27 16:08:05 | 显示全部楼层
行客 发表于 2019-2-27 16:07
没有看出错误。在线测试代码也并未提示错误:
https://www.nowcoder.com/pat/6/problem/4043

但是pta的测试点过不去
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-2-27 16:10:29 | 显示全部楼层
910201513 发表于 2019-2-27 16:08
但是pta的测试点过不去

测试地址是?
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-2-27 16:10:34 | 显示全部楼层
行客 发表于 2019-2-27 16:07
没有看出错误。在线测试代码也并未提示错误:
https://www.nowcoder.com/pat/6/problem/4043

https://pintia.cn/problem-sets/994805260223102976/problems
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-2-28 11:06:12 | 显示全部楼层
本帖最后由 行客 于 2019-2-28 11:13 编辑
行客 发表于 2019-2-27 21:54
这个应该还是算法上的问题,感觉你的算法不是很好理解。

比如,你的代码输入“0 1”做测试,结果就会出 ...


1.png
  1. #include<stdio.h>

  2. int main() {
  3.         int num[1000];        //存放被除数
  4.         int q[1000];        //存放商
  5.         int r, lenth=0;        //余数,被除数的位数
  6.         char c;        
  7.         int b,sign=0;        //除数 ,空格标识符        
  8.         while ((c=getchar())!='\n') {        //存储被除数跟除数
  9.                         if (sign == 0&&c!=' ') {        //存储被除数
  10.                                 num[lenth] = c - '0';
  11.                                 lenth++;
  12.                         }
  13.                         if(sign==1){        //存储除数
  14.                                 b = c - '0';
  15.                                 break;
  16.                         }
  17.                         if (c == ' ') {//遇到空格sign为1;
  18.                                 sign = 1;
  19.                         }
  20.         }
  21.         int diff = 0;        //除法中每一次的被除数
  22.         int qi = 0,ni=0;        //商,被除数中的数组坐标
  23.                 int i = 0;
  24.                 if (lenth == 1)
  25.                 {
  26.                         qi = 1;
  27.                         q[0] = num[0] / b;
  28.                         r = num[0] % b;
  29.                 }
  30.                 else
  31.                 {
  32.                         for (i = 0; i < lenth; i++) {               
  33.                                 diff = diff * 10 + num[ni];        
  34.                                 if (diff < b&&i==0) {        //被除数的第一位数小于除数,向后借位,坐标加一
  35.                                         ni++;
  36.                                         diff = diff * 10 + num[ni];
  37.                                         lenth = lenth - 1;
  38.                                 }        
  39.                                 ni++;
  40.                                 q[qi] = diff / b;                        
  41.                                 diff = diff%b;                        
  42.                                 qi++;                        
  43.                                 if (i == lenth - 1) {        //最后一次做除法的余数为整个除法的余数
  44.                                         r = diff;
  45.                                 }
  46.                         }
  47.                 }

  48.         for (i = 0; i < qi; i++) {
  49.                         printf("%d",q[i]);
  50.         }
  51.         printf(" %d\n",r);
  52.         return 0;
  53. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-2-28 11:06:57 | 显示全部楼层
910201513 发表于 2019-2-26 22:30
@行客
大佬,求教

已解决
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-2-28 11:48:21 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2019-2-28 12:26:09 | 显示全部楼层
行客 发表于 2019-2-27 21:54
这个应该还是算法上的问题,感觉你的算法不是很好理解。

比如,你的代码输入“0 1”做测试,结果就会出 ...

谢谢了 找出错误就好了  
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-17 18:35

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表