• 【Java】【PAT】Basic Level 1017 A除以B


    前言

    这是PTA平台上的PAT编程练习题。

    这道题用Java解会超时,要用C语言解。我把Java代码和C语言代码都放在这里,思路是一样的。


    题目 1017 A除以B

    作者 CHEN, Yue

    单位 浙江大学

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

    输入格式:

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

    输出格式:

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

    输入样例:

    123456789050987654321 7
    

    输出样例:

    176366841501410934

    思路

            题目中给的被除数很大(不超过1000位),要用字符串或者字符数组来处理。如果用字符串的来处理的话,可能会比较耗时,因此可以采用字符数组。计算的大致思路如下。每次循环就进行一次除法,被除数是两位(这两位都可以是0),除数是一位。(相当于模拟手动除法运算。)每次取出被除数的一位作为被除数的低位,与上一次得到的余数作为被除数的高位(这个数值可能是0,另外第一次的高位是初始化值0),共同组成一个两位数的被除数,进行除法运算。得到的商(一位)就存到数组中中去,余数(一位)就留到下一次循环的时候作为被除数的高位(通过乘以10来移到高位)。最后输出结果的时候要注意,商的最高位可能是0,要单独处理一下。


    Java代码

    Java代码在我的电脑上测试正确,在PTA平台上运行超时。大概是因为Java本身速度不够快。

    1. import java.io.*;
    2. class Main{
    3. public static void main(String[] args) throws IOException{
    4. //接收输入
    5. BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); //获取字符输入流
    6. String[] arr = br.readLine().split(" +"); //读取输入
    7. //声明变量
    8. String a = arr[0]; //被除数a的String
    9. int b = Integer.parseInt(arr[1]); //除数b的int
    10. char[] ch = a.toCharArray(); //将被除数String转为char数组
    11. int n = a.length(); //被除数a的长度
    12. char[] res = new char[n]; //最终的商char[]
    13. String q = ""; //q是商String
    14. int r = 0; //r是余数
    15. int t = 0; //部分余数
    16. int m = 0; //临时变量
    17. //开始计算
    18. for(int i=0;i//遍历被除数的每一位
    19. t = t * 10 + ( ch[i] - 48 ); //将原有余数移位,再取出被除数的最高位,转为int
    20. m = t; //暂存被除数
    21. t = t % b; //获取当前余数
    22. res[i] = (char)(m / b + 48); //把部分商存起来
    23. //q = q + (int)(m / b); //把部分商附加到最终结果上
    24. }
    25. r = t; //把最后一位余数作为最终的余数
    26. //输出
    27. for(int i=0;i
    28. if(i==0 && res[i]=='0') //如果商的第一位是0,就跳过
    29. continue;
    30. System.out.print(res[i]); //输出商的每一位
    31. }
    32. System.out.print(" " + r); //再输出余数
    33. }
    34. }
    35. /*测试的值
    36. String a = "123456789050987654321";
    37. int b = 7;
    38. */

    C语言代码

    C语言代码与上面的Java代码思路一致,只不过C语言代码运行更快一些,在PTA平台上所有测试点都通过。

    1. #include
    2. #include
    3. int main(){
    4. char a[1000], res[1000]; //a是被除数的字符数组,res是商的字符数组
    5. int b, n = 0, r = 0; //b是除数,n是记录商的字符数组长度,r是余数
    6. scanf("%s %d", a, &b); //读取输入
    7. for(int i=0; a[i]!='\0'; i++){ //遍历被除数
    8. r = r * 10 + (a[i] - '0'); //计算余数
    9. res[n++] = r / b + '0'; //计算商,把商加入到商的字符数组中
    10. r %= b; //计算余数
    11. }
    12. int i = 0;
    13. while(res[i]=='0') i++; //去除前导0
    14. if(i == n) printf("0"); //如果商为0,则输出0和余数
    15. while(i < n) printf("%c", res[i++]); //输出商的每一位
    16. printf(" %d", r); //输出余数
    17. return 0;
    18. }

  • 相关阅读:
    echarts数值过多时X轴滚动显示
    线下实体店铺会员引流的四种方法-未完待续
    【论文阅读】EDPLVO: Efficient Direct Point-Line Visual Odometry
    【Linux系统编程(文件编程)】之创建、打开文件
    天眼查数据采集、分析、深度挖掘
    GraphQL入门
    uniapp开发的跳转到小程序
    纯CSS 自定义radio单选按扭、checkbox复选框 默认样式
    现在大火的低代码是怎么回事?进来聊聊低代码
    golang make和new的区别
  • 原文地址:https://blog.csdn.net/Dr_Cheeze/article/details/133654180