洛谷 题解 P1604 【B进制星球】
题目:P1604 B进制星球
本人提交记录:R6292872
作为一个极其无聊的人,我没事干地写了operator。。。
思路很简单:
读入b
读入b进制的x,y
ans = x + y
输出ans
用了operator,貌似难解释一点。
但我认为,以大家那都高于我的智商,不会不理解高精加法。
我只需要介绍一下一些变量和函数%%%
全局变量 b : b进制
struct类型 bint : b进制高精数
bint类型 x,y,ans : x,y用于输入,ans存储答案值
还要介绍一下bint类型的变量&方法orz:
beta 存储高精数
len 存储高精数长度
bint() 初始化
mem() 初始化,形参为初始化后每位的值
operator + () 加法operator定义
operator >> () 输入operator定义
operator << () 输出operator定义
最后上代码:
#include <string.h>
#include <iostream>
#define MAX 2001
using namespace std;
int b;
struct bint {
int beta[MAX];
int len;
bint()
{
mem(0);
len = 0;
}
void mem(int cmd)
{
memset(beta, cmd, sizeof(beta));
}
bint operator + (const bint &other) const
{
if (len == 0) return other;
if (other.len == 0) return *this;
bint ans;
int maxlen = len > other.len ? len : other.len;
for (int i = 0; i < maxlen; i++) {
ans.beta[i] += beta[i] + other.beta[i];
ans.beta[i + 1] += ans.beta[i] / b;
ans.beta[i] = ans.beta[i] % b;
}
if (ans.beta[maxlen] != 0) ans.len = maxlen + 1;
else ans.len = maxlen;
return ans;
}
friend istream &operator >> (istream &in, bint &other)
{
string str;
in >> str;
for (int i = 0; i < str.size(); i++) {
if (str[i] > '9') other.beta[str.size() - i - 1] = str[i] - 55;
else other.beta[str.size() - i - 1] = str[i] - 48;
}
other.len = str.size();
}
friend ostream &operator << (ostream &out, bint &other)
{
for (int i = other.len - 1; i >= 0; i--) {
if (other.beta[i] > 9) out << (char)(other.beta[i] + 55);
else out << (char)(other.beta[i] + 48);
}
}
};
int main()
{
bint x, y, ans;
cin >> b;
cin >> x;
cin >> y;
ans = x + y;
cout << ans;
return 0;
}
慢慢看。。。
洛谷 题解 P1604 【B进制星球】的更多相关文章
- 洛谷——P1604 B进制星球
P1604 B进制星球 题目背景 进制题目,而且还是个计算器~~ 题目描述 话说有一天,小Z乘坐宇宙飞船,飞到一个美丽的星球.因为历史的原因,科技在这个美丽的星球上并不很发达,星球上人们普遍采用B(2 ...
- 洛谷 P1604 B进制星球
P1604 B进制星球 题目背景 进制题目,而且还是个计算器~~ 题目描述 话说有一天,小Z乘坐宇宙飞船,飞到一个美丽的星球.因为历史的原因,科技在这个美丽的星球上并不很发达,星球上人们普遍采用B(2 ...
- 洛谷P1066 2^k进制数(题解)(递推版)
https://www.luogu.org/problemnew/show/P1066(题目传送) (题解)https://www.luogu.org/problemnew/solution/P106 ...
- 洛谷 P1066 2^k进制数
P1066 2^k进制数 题目描述 设r是个2^k 进制数,并满足以下条件: (1)r至少是个2位的2^k 进制数. (2)作为2^k 进制数,除最后一位外,r的每一位严格小于它右边相邻的那一位. ( ...
- 洛谷P1066 2^k进制数
P1066 2^k进制数 题目描述 设r是个2^k 进制数,并满足以下条件: (1)r至少是个2位的2^k 进制数. (2)作为2^k 进制数,除最后一位外,r的每一位严格小于它右边相邻的那一位. ( ...
- [NOIP2006] 提高组 洛谷P1066 2^k进制数
题目描述 设r是个2^k 进制数,并满足以下条件: (1)r至少是个2位的2^k 进制数. (2)作为2^k 进制数,除最后一位外,r的每一位严格小于它右边相邻的那一位. (3)将r转换为2进制数q后 ...
- 洛谷P1582——倒水(进制,数学)
https://www.luogu.org/problem/show?pid=1582 题目描述 一天,CC买了N个容量可以认为是无限大的瓶子,开始时每个瓶子里有1升水.接着~~CC发现瓶子实在太多了 ...
- 洛谷1066 2^k进制数
原题链接 大力猜结论竟然猜对了.. 对于一对\(k,w\),我们可以把\(w\)位划分成\(k\)位一段的形式,每一段就是转换成十进制后的一位,这个从题面的解释中应该可以理解. 先不考虑可能多出(即剩 ...
- 洛谷P4135 Ynoi2016 掉进兔子洞 (带权bitset?/bitset优化莫队 模板) 题解
题面. 看到这道题,我第一反应就是莫队. 我甚至也猜出了把所有询问的三个区间压到一起处理然后分别计算对应询问答案. 但是,这么复杂的贡献用什么东西存?难道要开一个数组 query_appear_tim ...
随机推荐
- tomcat日志(1)
tomcat日志配置之一自带log 2014-03-19 09:58 33737人阅读 评论(2) 收藏 举报 分类: java(49) 问题 tomcat每次启动时,自动在logs目录下生产以下日志 ...
- 用maven创建web项目(spring Mvc)
用maven创建web项目(spring Mvc) 1.打开cmd进入到你要创建maven项目的目录下: 2.输入以下命令.然后根据提示输入相应的groupId.artifactId.version: ...
- 领扣(LeetCode)3的幂 个人题解
给定一个整数,写一个函数来判断它是否是 3 的幂次方. 示例 1: 输入: 27 输出: true 示例 2: 输入: 0 输出: false 示例 3: 输入: 9 输出: true 示例 4: 输 ...
- Robot Framework自动化测试环境搭建
robotFramework是一个通用的自动化测试框架来进行验收测试和验收测试驱动开发模式,它具有易于使用的表格的测试数据和关键字测试驱动方法,其测试功能可通过实现与python或java的测试库进行 ...
- aws msk
1. 建立3个私网子网 2. 建立msk
- python3 pip报错 TypeError: 'module' object is not callable
使用命令:python -m pip install xx即可,需要在pip前加python -m
- (三)OpenStack---M版---双节点搭建---Keystone安装和配置
↓↓↓↓↓↓↓↓视频已上线B站↓↓↓↓↓↓↓↓ >>>>>>传送门 1.创建keystone数据库 2.创建随机密码作为管理员令牌 3.安装openstack-ke ...
- 【搞定面试官】谈谈你对JDK中Executor的理解?
## 前言 随着当今处理器计算能力愈发强大,可用的核心数量越来越多,各个应用对其实现更高吞吐量的需求的不断增长,多线程 API 变得非常流行.在此背景下,Java自JDK1.5 提供了自己的多线程框架 ...
- 深度学习解决NLP问题:语义相似度计算
在NLP领域,语义相似度的计算一直是个难题:搜索场景下query和Doc的语义相似度.feeds场景下Doc和Doc的语义相似度.机器翻译场景下A句子和B句子的语义相似度等等.本文通过介绍DSSM.C ...
- apache虚拟主机配置的3种方式
Apache的虚拟主机功能 (Virtual Host) 是可以让一台服务器基于IP.主机名或端口号实现提供多个网站服务的技术. 下面我介绍一下这3种方式具体的配置流程: 一.基于ip地址 首先我们需 ...