a-2b
 

描述

输入两个高精度数a和b,求a-2b的值。

输入

输入两行,第一行是被减数a,第二行是减数b(a>2b并且a,2b的位数不同且不存在借位,且b+b不存在进位)。

输出

一行,即所求的差。

输入样例 1

888888888888888888888888
44444444

输出样例 1

888888888888888800000000

#include <iostream>
#include <cstring>
using namespace std;
int main() {
char a1[256] = {},b1[256] = {};
int a[256] = {},b[256] = {},c[256] = {},lena,lenb,i;
int lenc = 0;
cin >> a1 >> b1;
lena = strlen(a1);
lenb = strlen(b1);
for (i = 0; i <= lena-1; i ++) {
a[lena-i-1] = a1[i] - 48;
}
for (i = 0; i <= lenb-1; i ++) {
b[lenb-i-1] = b1[i] - 48;
}
while (lenc<lena||lenc<lenb) {
c[lenc] = a[lenc] - b[lenc] - b[lenc];
lenc ++;
}
while ((c[lenc-1] == 0)&&(lenc > 1)) {
lenc--;
}
for (i = lenc-1;i >= 0;i --) {
cout << c[i];
}
return 0;
}
"#include <iostream>": "包含C++标准输入输出流库。",
"#include <cstring>": "包含C++字符串操作库。",
"using namespace std;": "使用C++标准命名空间,这样就可以直接使用标准库中的名字,例如cin, cout等。",
"int main() {": "程序的主函数开始。",
"char a1[256] = {},b1[256] = {};": "声明两个字符数组a1和b1,长度均为256,并初始化为空字符串。",
"int a[256] = {},b[256] = {},c[256] = {},lena,lenb,i;": "声明三个整数数组a, b和c,长度均为256,并初始化为0。同时声明了三个整数变量lena, lenb和i。",
"int lenc = 0;": "声明一个整数变量lenc并初始化为0,用于记录数组c的长度。",
"cin >> a1 >> b1;": "从标准输入读取两个字符串,分别赋值给a1和b1。",
"lena = strlen(a1);": "计算字符串a1的长度并赋值给lena。",
"lenb = strlen(b1);": "计算字符串b1的长度并赋值给lenb。",
"for (i = 0; i <= lena-1; i ++) { a[lena-i-1] = a1[i] - 48; }": "将字符串a1的每个字符(按逆序)转换为对应的数字,并存储在数组a中。",
"for (i = 0; i <= lenb-1; i ++) { b[lenb-i-1] = b1[i] - 48; }": "将字符串b1的每个字符(按逆序)转换为对应的数字,并存储在数组b中。",
"while (lenc<lena||lenc<lenb) { c[lenc] = a[lenc] - b[lenc] - b[lenc]; lenc ++; }": "执行大数减法,将数组a和b对应位置的数字相减,并将结果存储在数组c中。当lenc小于a或b的长度时继续执行。",
"while ((c[lenc-1] == 0)&&(lenc > 1)) { lenc--; }": "去掉结果数组c前导的0,如果最后一位是0并且lenc大于1,则将lenc减1。",
"for (i = lenc-1;i >= 0;i --) { cout << c[i]; }": "逆序输出数组c的内容,即输出大数减法的结果。",
"return 0;": "主函数返回0,表示程序正常结束。",
"}": "主函数结束。"
#include <iostream>
#include <string>
using namespace std; int main() {
string a, b;
cin >> a >> b;
int len_a = a.length(), len_b = b.length();
int diff = len_a - len_b; // a-2b的位数差
string ans = a.substr(0, diff); // 截取a的前diff位
for (int i = 0; i < len_b; i++) {
int sub = (a[i+diff] - '0') - 2 * (b[i] - '0'); // 计算每一位的差
if (sub < 0) { // 需要借位
sub += 10;
ans[i]--; // 借位操作
}
ans += to_string(sub); // 拼接差值
}
cout << ans << endl;
return 0;
}
#include<bits/stdc++.h>
using namespace std;
int main(){
char a1[1001]={},a2[1001]={};
int b1[1001]={},b2[1001]={},b3[1001]={};
cin>>a1>>a2;
int len1=strlen(a1);
int len2=strlen(a2);
if(len2>len1 || (len2==len1) && strcmp(a1,a2)<0){
swap(a1,a2);
swap(len1,len2);
cout<<"-";
}
for(int i=0;i<len1;i++){
b1[len1-1-i]=a1[i]-'0';
}
for(int i=0;i<len2;i++){
b2[len2-1-i]=a2[i]-'0';
}
int lenc=len1;
for(int i=0;i<lenc;i++){
if(b1[i]<b2[i]){
b1[i]+=10;
b1[i+1]--;
} b3[i]=b1[i]-b2[i];
}
while(b3[lenc-1]==0){
lenc--;
if(lenc==1){
break;
}
}
for(int i=lenc-1;i>=0;i--){
cout<< b3[i] ;
}
return 0;
}

a-2b的更多相关文章

  1. <开心一笑> 码农 黑客和2B程序员之间的区别

    笔记本电脑 码农: 黑客: 2B程序员: 求2的32次方: 码农: System.out.println(Math.pow(2, 32)); 黑客: System.out.println(1L< ...

  2. RPi 2B USB 远程桌面

    /******************************************************************** * RPi 2B USB 远程桌面 * 说明: * 用作废的 ...

  3. Android telnet RPi 2B

    /************************************************************************* * Android telnet RPi 2B * ...

  4. RPi 2B Android telnet ssh

    /*********************************************************************** * RPi 2B Android telnet ssh ...

  5. 【树莓派2B倒腾日志】之安装系统及配置

    15号树莓派到手到现在,折腾了也有一小周,自己摸索着,装了系统,登上SSH,更新了源,连了VNC,换上wifi,亮了小灯.再到今天捣鼓了下数码管,回头想想,该写个日志记录一下这一周的所得,自己总结也方 ...

  6. RPi 2B Documentation

    /********************************************************************** * RPi 2B Documentation * 声明: ...

  7. RPi 2B Raspbian SD卡内部架构

    /***************************************************************************** * RPi 2B Raspbian SD卡 ...

  8. RPi 2B Raspbian system install

    /***************************************************************************** * RPi 2B Raspbian系统安装 ...

  9. RPi 2B SD read-only filesytem

    /**************************************************************************** * RPi 2B SD read-only ...

  10. RPi 2B 中文语言包

    /************************************************************************* * RPi 2B 中文语言包 * 声明: * 本文 ...

随机推荐

  1. .NET周报 【6月第3期 2023-06-18】

    国内文章 揭秘 Task.Wait https://www.cnblogs.com/eventhorizon/p/17481757.html Task.Wait 是 Task 的一个实例方法,用于等待 ...

  2. MVC 模式和三层架构

    1. MVC 模式 ‍ MVC 模式和三层架构是一些理论的知识,将来我们使用了它们进行代码开发会让我们代码维护性和扩展性更好. ‍ MVC 是一种分层开发的模式,其中: M:Model,业务模型,处理 ...

  3. 人工智能智能城市(AIinSmartCities)领域的100篇热门博客文章标题如下:

    目录 人工智能智能城市(AI in Smart Cities)领域的100篇热门博客文章标题如下: 1.<智能城市与大数据:未来城市大脑的发展方向> 2.<智能交通系统的设计与实现& ...

  4. 跟着 GPT-4 从0到1学习 Golang 并发机制(一)

    目录 一.前言 二.开聊 2.1 Golang 里的并发机制介绍 2.2 Goroutine 与线程 2.3 Goroutine 与线程的调度开销 2.4 用户态和内核态 2.5 Golang 并发编 ...

  5. Java IO流 - 字节流的使用详细介绍

    IO流的基本介绍: IO流的概述: i 表示intput,是数据从硬盘文件读入到内存的过程,称之输入,负责读. o 表示output,是内存程序的数据从内存到写出到硬盘文件的过程,称之输出,负责写. ...

  6. 用 Rust 生成 Ant-Design Table Columns

    经常开发表格,是不是已经被手写Ant-Design Table的Columns整烦了? 尤其是ToB项目,表格经常动不动就几十列.每次照着后端给的接口文档一个个配置,太头疼了,主要是有时还会粘错就尴尬 ...

  7. 论文解读()《Cluster Alignment with a Teacher for Unsupervised Domain Adaptation》

    Note:[ wechat:Y466551 | 付费咨询,非诚勿扰 ] 论文信息 论文标题:Cluster Alignment with a Teacher for Unsupervised Doma ...

  8. MISC杂项解题思路

    首先拿到一个杂项的附件 第一步要判断 是什么类型的杂项题目 附件是什么内容 是图片? 是压缩包? 是磁盘文件? 还是其他未知的东西 第一步的判断能够直接将解题思路精准定位到正确的区域下 加快解题速度 ...

  9. DBSCAN聚类

    一.概述   DBSCAN(Density-Based Spatial Clustering of Applications with Noise)是一种基于密度的聚类算法,簇集的划定完全由样本的聚集 ...

  10. MySQL查询语句的执行过程

    SQL语句的查询过程 文章源自:极客时间-MySQL核心知识45讲 1. 前言 先看一张图和一个简单的SQL查询语句:select * from T where ID=10; 2. 概述 大体来说,M ...