当前位置: 首页 > 编程笔记 >

加基数n

郜彦
2023-03-14
本文向大家介绍加基数n,包括了加基数n的使用技巧和注意事项,需要的朋友参考一下

在这个问题上,给出了两个数字。这些数字的底数为n。我们还必须在以n为底的加法中找到这些数字的结果。

首先,将数字转换为十进制数字。从十进制值中,我们可以简单地将它们相加。最后,数字再次转换为以n为底的数字。

n个基数以字符串形式给出,因为对于那些基数大于9的数字,它可能包含一些字母来表示数字,例如十六进制数字,则有6个字母(AF)。

输入输出

Input: The base of a number system: 16
First number 2C
Second number 5F
Output:
The result of addition is: 8B

算法

baseNtoDec(number,base)

输入-以N为底的数字字符串,以N为底的值。

输出-以N为底的数字的十进制等效项。

Begin
   len := length of number
   power := 1
   num := 0

   for i := len -1 down to 0, do
      if number[i] >= base, then
         return invalid number
      num := num + number[i] * power
      power := power * base
   done

   return num
End

decToBaseN(dec,base)

输入:十进制数,以N为基数的十进制数。

输出:以N为底的数字字符串。

Begin
   while dec > 0, do
      res := concatenate (dec mod base) with res
      dec := dec / base
   done

   reverse the result
   return res
End

addBaseN(num1,num2,base)

输入: 以N为底的两个数字,即N的值。

输出: 加N后的数字。

Begin
   dec1 := baseNtoDec(num1, base)
   dec2 := baseNtoDec(num2, base)
   sum := decToBaseN(dec1 + dec2, base)
   return sum
End

示例

#include<iostream>
#include<algorithm>
using namespace std;

int getVal(char c) {
   if(c >= '0' && c<='9')
      return int(c-'0');    //decimal value of given number
   else
      return int(c-'A'+10);    //for Alphanumeric numbers
}

char revVal(int n) {
   if(n >= 0 && n <=9)
      return char(n+'0');    //character value of given number
   else
      return char(n+'A'-10);    //for Alphanumeric numbers, get alphabet from decimal
}

int baseNtoDec(string number, int base) {
   int len = number.size();
   int power = 1;
   int num = 0;

   for(int i = len-1; i>= 0; i--) {    //from last digit to first digit
      if(getVal(number[i]) >= base)
         return INT_MIN;    //when a digit is >= base, return -ve infinity as error
      num += getVal(number[i])*power;
      power = power*base;
   }
   return num;
}

string decToBaseN(int dec, int base) {
   string res = "";    //empty string
   while(dec > 0) {
      res += revVal(dec%base);
      dec /= base;
   }

   reverse(res.begin(), res.end());    //reverse the string to get final answer
   return res;
}

int main() {
   int base;
   string num1, num2, sum;
   cout << "Enter Base: "; cin >> base;
   cout << "Enter first number in base "<<base<<": ";cin >> num1;
   cout << "Enter second number in base "<<base<<": ";cin >> num2;
   sum = decToBaseN((baseNtoDec(num1, base) + baseNtoDec(num2, base)), base);
   cout << "The result of addition is: " << sum;
}

输出结果

Enter Base: 16
Enter first number in base 16: 2C
Enter second number in base 16: 5F
The result of addition is: 8B
 类似资料:
  • 我正在尝试将计数器列(和)添加到数据帧中,但使用等没有成功。下面是输入数据帧()和所需输出数据帧()以及几个错误输出的代码的代表。 通过排列两个变量来添加计数器列(dplyr) https://community.rstudio.com/t/how-to-add-a-counter-to-each-group-in-dplyr/12986/2 https://dplyr.tidyverse.org

  • 坦率地说,我一直在思考如何实现一些超出我数学能力的东西。因此,请随意尝试并为我指出正确的方向,而不是完整的代码解决方案,我将非常感谢您的帮助。 所以,假设我对文本进行了分析,并生成了不同两个字符组合的频率表。我已将这些存储在26x26阵列中。如。 所以我想随机选择这两个字符组合,但我想根据频率来“权衡”我的选择。也就是说,上面的AB应该是AA的“可能性”的15倍。而且,很明显,选择永远不应该返回类

  • 问题内容: 我试图找出如何加载和呈现基本HTML文件的方法,因此不必编写类似以下的代码: 问题答案: 我只是找到 了 使用fs库的 一种 方法。我不确定这是否最干净。 基本概念只是原始文件读取和转储内容。不过,仍然可以接受更清洁的选择!

  • 8.1.1 代码介绍 基础统计代码用于加载SiteMonitor JS监测脚本, 是系统收数的基础。 在网页上正确添加基础统计代码后,即可实现系统诸多报表的数据收集。 8.1.2 代码导出 有以下2种方式可导出代码: 新建站点时,保存并导出基础统计代码 已有站点,通过查看后台的 设置 > 统计代码 导出的代码样例 <script> (function(a, e, f, g, b, c, d) {a

  • 基数树 正如你所知道的 Linux 内核通过许多不同库以及函数提供各种数据结构以及算法实现。 这个部分我们将介绍其中一个数据结构 Radix tree。Linux 内核中有两个文件与 radix tree 的实现和API相关: include/linux/radix-tree.h lib/radix-tree.c 首先说明一下什么是 radix tree 。Radix tree 是一种 压缩 tr

  • 简介 Java类加载器是Java运行时环境(Java Runtime Environment)的一部分,负责动态加载Java类到Java虚拟机的内存空间中。类通常是按需加载,即第一次使用该类时才加载。 由于有了类加载器,Java运行时系统不需要知道文件与文件系统。每个Java类必须由某个类加载器装入到内存。 类装载器子系统涉及Java虚拟机的其他几个组成部分,以及几个来自java.lang库的类。