一千题,No.0031(A除以B)

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

输入格式:

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

输出格式:

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

输入样例:

复制代码
123456789050987654321 7

输出样例:

复制代码
17636684150141093474 3

解题思路:

模拟除法的步骤即可

需要注意的是:需要删除先输出的0,否则可能会输出041234 2这样不符合正常数字的结果,还需要在被除数小于除数的时候输出0,这就需要判断了

c++代码如下:

cpp 复制代码
#include <bits/stdc++.h>

using namespace std;

int main()
{
   string a;//被除数
   int b;//除数
   cin >> a;
   cin >> b;
   int temp = 0;//余数,刚开始肯定赋值为0
   string res = "";//结果,方便去除多余的0
   
   //模拟除法的步骤
   for(int i = 0;i < a.size();++i)
   {
       char c = a[i];
       int num = atoi(&c);
       num += temp*10;//加上余数
       res += to_string(num/b);
       temp = num%b;
   }
   
   //删除多余的0
   while(res[0] == '0')
   {
       res = res.substr(1);
   }

   if(res == "")//判断被除数是否小于除数
   {
       res += "0";
   }
   cout << res << " " << temp;
}
相关推荐
南境十里·墨染春水几秒前
C++ 笔记 thread
java·开发语言·c++·笔记·学习
南境十里·墨染春水2 分钟前
C++ 笔记 高级线程同步原语与线程池实现
java·开发语言·c++·笔记·学习
瞎折腾啥啊14 分钟前
CMake FetchContent与ExternalProject
c++·cmake·cmakelists
三品吉他手会点灯1 小时前
STM32 VSCode 开发-C/C++的环境配置中,找不到C/C++: Edit Configurations选项
c语言·c++·vscode·stm32·单片机·嵌入式硬件·编辑器
逻辑驱动的ken1 小时前
Java高频面试考点场景题09
java·开发语言·数据库·算法·oracle·哈希算法·散列表
帅小伙―苏2 小时前
力扣42接雨水
前端·算法·leetcode
AI科技星2 小时前
精细结构常数α的几何本源:从第一性原理的求导证明、量纲分析与全域验证
算法·机器学习·数学建模·数据挖掘·量子计算
6Hzlia2 小时前
【Hot 100 刷题计划】 LeetCode 287. 寻找重复数 | C++ 数组判环 (快慢指针终极解法)
c++·算法·leetcode
MegaDataFlowers2 小时前
26.删除有序数组中的重复项
算法
Robot_Nav3 小时前
DPMPC-Planner:复杂静态环境与动态障碍物下的无人机实时轨迹规划框架
c++·无人机·mpc