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 中文语言包 * 声明: * 本文 ...
随机推荐
- Python Selenium UI自动化测试
Python Selenium UI自动化测试 1.自动化测试基础 1.1 自动化测试的定义 将人为的测试行为转化为机器自动执行的过程 1.2 自动化测试的目的 减少成本,提高测试效率 减少人为因素对 ...
- 使用 OpenAPI 构建 RESTful API 文档
作为一名开发者,往往需要编写程序的 API 文档,尤其是 Web 后端开发者,在跟前端对接 HTTP 接口的时候,一个好的 API 文档能够大大提高协作效率,降低沟通成本,本文就来聊聊如何使用 Ope ...
- 为什么使用ioutil.ReadAll 函数需要注意
1. 引言 当我们需要将数据一次性加载到内存中,ioutil.ReadAll 函数是一个方便的选择,但是ioutil.ReadAll 的使用是需要注意的. 在这篇文章中,我们将首先对ioutil.Re ...
- 【阅读笔记】超分之LANR-NLM算法
论文信息 [Single Image Super-Resolution via Locally Regularized Anchored Neighborhood Regression and Non ...
- 【转载】Linux虚拟化KVM-Qemu分析(五)之内存虚拟化
原文信息 作者:LoyenWang 出处:https://www.cnblogs.com/LoyenWang/ 公众号:LoyenWang 版权:本文版权归作者和博客园共有 转载:欢迎转载,但未经作者 ...
- 使用Locust进行性能测试
当涉及到评估应用程序或服务的性能时,Locust是一个功能强大且易于使用的开源工具.本文将介绍Locust的基本概念和使用方法. 什么是Locust? Locust是一个用于编写.运行和分析负载测试的 ...
- RAT蓝队自动化测试框架
RAT蓝队自动化测试框架 介绍 RAT 是根据 MITRE ATT&CK 战术矩阵测试蓝队检测能力的脚本框架,由 python2.7 编写,共有 50 多种不同 ATT&CK 技术点和 ...
- keras-retinanet 环境搭建 tensorflow2.3
keras-retinanet 环境搭建 tensorflow2.3 前言 搭建好了 [tensorflow-gpu 2.5] 之后,接到一个指示,跑起来这个开源的库 keras-retinanet ...
- Angular: 点击一次按钮,增加一个元素
解决方案 思路 在组件的typesscript文件中,创建一个数组来存储每个按钮的信息 在模板中使用 *ngFor 指令来循环渲染按钮列表 在按钮事件的处理函数中,每次点击按钮时向按钮数组添加一个新的 ...
- linux设置信号量系统参数
前言 信号量是IPC(进程间通信)机制的一种,用于协调多个进程或线程对共享数据的读写操作,本质上是一个计数器.类似于锁,主要用于保护共享资源,控制同时访问资源的进程数. 信号量只允许调用者对它进行等待 ...