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的更多相关文章
- <开心一笑> 码农 黑客和2B程序员之间的区别
笔记本电脑 码农: 黑客: 2B程序员: 求2的32次方: 码农: System.out.println(Math.pow(2, 32)); 黑客: System.out.println(1L< ...
- RPi 2B USB 远程桌面
/******************************************************************** * RPi 2B USB 远程桌面 * 说明: * 用作废的 ...
- Android telnet RPi 2B
/************************************************************************* * Android telnet RPi 2B * ...
- RPi 2B Android telnet ssh
/*********************************************************************** * RPi 2B Android telnet ssh ...
- 【树莓派2B倒腾日志】之安装系统及配置
15号树莓派到手到现在,折腾了也有一小周,自己摸索着,装了系统,登上SSH,更新了源,连了VNC,换上wifi,亮了小灯.再到今天捣鼓了下数码管,回头想想,该写个日志记录一下这一周的所得,自己总结也方 ...
- RPi 2B Documentation
/********************************************************************** * RPi 2B Documentation * 声明: ...
- RPi 2B Raspbian SD卡内部架构
/***************************************************************************** * RPi 2B Raspbian SD卡 ...
- RPi 2B Raspbian system install
/***************************************************************************** * RPi 2B Raspbian系统安装 ...
- RPi 2B SD read-only filesytem
/**************************************************************************** * RPi 2B SD read-only ...
- RPi 2B 中文语言包
/************************************************************************* * RPi 2B 中文语言包 * 声明: * 本文 ...
随机推荐
- PySide6(Qt for Python) QTableWidget表头边框线问题
这个问题是在Windows10平台下特有问题. 网络上有很多Qt C++的解决方案.但是没有特定的PySide6的解决方案(以下是Qt C++的解决方案). https://blog.csdn.net ...
- 从GaussDB(DWS)的技术演进,看数据仓库的积淀与新生
摘要:随着云计算的兴起和渗透,云数仓成为了数仓技术演进的新阶段,并且逐渐成为了众多企业的共同选择. 本文分享自华为云社区<从GaussDB(DWS)的技术演进,看数据仓库的积淀与新生>,作 ...
- PowerDesigner反向导入表+PowerDesigner的ER图设计+PowerDesigner连接外键的线(版本16.5)
使用PowerDesigner导入表+PowerDesigner画ER图+PowerDesigner设置外键 ps: ①ER图:就是PD中的 Physical Diagram 一.导入表,并设置备注为 ...
- Doris写入数据异常提示actual column number in csv file is less than schema column number
版本信息: Flink 1.17.1 Doris 1.2.3 Flink Doris Connector 1.4.0 写入方式 采用 String 数据流,依照社区网站的样例代码,在sink之前将数据 ...
- 2021级HAUT新生周赛题解汇总
2021级HAUT新生周赛(一)题解@张君毅:第一场 2021级HAUT新生周赛(二)题解@李亚凯:第二场 2021级HAUT新生周赛(三)题解@李晨曦:第三场 2021级HAUT新生周赛(四)题解@ ...
- PWM点灯
目录 PWM脉冲宽调点灯 前言 1.什么是PWM 2.PWM的实现 3.PWM实现步骤(通用定时器) 3.1 打开定时器的时钟 3.2 配置端口 3.3 设置定时器 3.4 设置PWM 3.5 完整代 ...
- Avalonia中用FluentAvalonia+DialogHost.Avalonia实现界面弹窗和对话框
Avalonia中用FluentAvalonia+DialogHost.Avalonia实现界面弹窗和对话框 本文是项目中关于 弹窗界面 设计的技术分享,通过 FluentAvalonia+Dialo ...
- sshpass快速登录远程主机:s2
#!/bin/bash passwd= if [ $# -ne 1 ] then echo "$0 [31|37|61]" fi if command -v sshpass the ...
- 如何编写难以维护的React代码?耦合组件
如何编写难以维护的React代码?耦合组件 在许多项目中,我们经常会遇到一些难以维护的React代码.其中一种常见的情况是:子组件直接操作父组件方法,从而导致父子组件深度耦合.这样的实现让子组件过于依 ...
- 2021-4-19 vs加速启动小技巧之intellitrace
在选项界面中将intellitrace的启用关闭后对于程序的打开有加速作用.