当前位置: 首页 > 编程日记 > 正文

高精度进制转换

高精度进制转换:

       对于普通的不是非常大的数的相互转换,我们一般採用不断模取余的方法,比如:将10进制数m转换成n进制数,则对m模n取余就可以。可是,假设是一个有几百、几千或者很多其它位的大数呢?显然这样的模取余的方法不再适用了。那怎样求解此类大数的转换呢?接下来。介绍一种通用方法。

        我们将一个大数的每一位看做是一个单独的数,可是却不是全然孤立的,与其他位置上的数有关联,从该数的最高位開始,对该位上的数除以要转换的进制基数。得到商和余数。商代替原来该位上的数,进行下一位的同样操作。可是注意下一位的除数不不过该位的数,而是前一次的余数乘以大数的进制基数加上该位的数。如此循环,到所以位都除过一次。记录最后一位操作得到的余数。然后将上次的商作为除数。继续上次的操作,直到商为零。

逆序输出每次记录的余数,即是要求的数。








接下来提供一些函数,仅供參考:(下面函数是1到62进制的相互转换,当中定义0=0。1=1,……。9=9。A=10,B=11,……Y=34。Z=35,a=36,b=37。……,y=60。z=61。

第一个函数:将字符转换成相应进制的整数

代码例如以下:C代码

#include<stdio.h>
#include<string.h>
//第一个函数
int GetNum(char c)//将字符转换成相应进制的整数
{if(c>='0'&&c<='9') return c-'0';if(c>='A'&&c<='Z' ) return c-'A'+10;return c-'a'+36;
}int main()
{int i,n;char str[100];scanf("%s",str);n=strlen(str);for(i=0;i<n-1;i++)printf("%d ",GetNum(str[i]));printf("%d\n",GetNum(str[n-1]));return 0;
}

第一行是输入,第二行到第四行是输出。



第二个函数:将相应进制整数转换成相应的字符

代码例如以下:C代码

#include<stdio.h>
#include<string.h>
//第二个函数
char GetChar(int i)//将相应进制整数转换成相应的字符
{if(i>=0&&i<=9) return i+'0';if(i>=10&&i<=35) return i-10+'A';return i-36+'a';
}int main()
{int i,n,num;scanf("%d",&n);for(i=0;i<n;i++){scanf("%d",&num);printf("%c ",GetChar(num));if(i==9||i==35)printf("\n");}return 0;
}

    一至四行是输入,最后三行是输出。

   

还有几个函数。可是要调用其他函数,在这里总体给出(请具体看代码及凝视):

代码例如以下:C/C++代码

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define MAXSIZE 600//大数的最大位数
char str[MAXSIZE];//储存须要转换的大数,以字符形式储存
//oldbase:原基数。newbase:新基数。len:大数的长度
int oldbase,newbase,len,k;
//a[MAXSIZE];储存大数的最小整型。注意a[0]没有使用;r[MAXSIZE]:储存余数,即所求数的每一位
int a[MAXSIZE],r[MAXSIZE];
int GetNum(char c)//将字符转换成相应进制的整数
{if(c>='0'&&c<='9') return c-'0';if(c>='A'&&c<='Z' ) return c-'A'+10;return c-'a'+36;
}
char GetChar(int i)//将相应进制整数转换成相应的字符
{if(i>=0&&i<=9) return i+'0';if(i>=10&&i<=35) return i-10+'A';return i-36+'a';
}
void ChToNum()//调用函数将字符串转化成相应进制的整数。按位转化
{len=strlen(str);//測量字符串的长度//遍历每个字符,一一相应转化,注意没有使用a[0]for(int i=1;i<=len;i++){a[i]= GetNum(str[i-1]);}
}
void alter()//转化函数。核心代码
{int m=1;k=0;while(m<=len){int i,t = 0;//对数的每一位除新基数求商求余for(i=m;i<=len;i++){t=t*oldbase+a[i];//计算除数a[i]=t/newbase;//求商t%=newbase;//求余}r[k++]=t;//记录最后一个余数for(i=1;i<=len&&!a[i];i++);//去除前导0m=i;}
}
void print()//输出函数
{printf("%d %s\n%d ",oldbase,str,newbase);while(k--)//逆序输出余数,即是结果{printf("%c",GetChar(r[k]));}printf("\n\n");
}
int main()
{int n;while(scanf("%d",&n)!=EOF){while(n--){scanf("%d %d %s",&oldbase,&newbase,str);ChToNum();//字符转换为整型alter();//转化print();//函数调用输出结果}}return 0;
}


输入:

8

62  2  abcdefghiz

10  16  1234567890123456789012345678901234567890

16  35  3A0C92075C0DBF3B8ACBC5F96CE3F0AD2

35  23  333YMHOUE8JPLT7OX6K9FYCQ8A

23  49  946B9AA02MI37E3D3MMJ4G7BL2F05

49  61  1VbDkSIMJL3JjRgAdlUfcaWj

输出:



相关文章:

远程办公,你希望在家工作几天?

受疫情影响&#xff0c;员工的工作方式不得不发生改变。在过去短短的几个月内&#xff0c;远程办公从偶然一次变成了常态化。随着疫情的反复&#xff0c;远程办公再次成为了许多企业的选择。3月份携程正式启动了“32”混合办公模式&#xff0c;即每周有1-2天&#xff0c;员工可…

python爬虫日志(9)爬取代理

2019独角兽企业重金招聘Python工程师标准>>> 话不多说&#xff0c;直接上代码&#xff0c;很简单&#xff0c;很容易看懂 import requests from bs4 import BeautifulSoup import randomdef get_ip_list():print("正在获取代理列表...")ip_url http://ww…

使php支持mbstring库以及使用

1.执行yum install php-mbstring2. 修改php.ini (这一步非常重要, 部分lxadmin版本无法自动修改)echo ‘extensionmbstring.so’ >>/etc/php.ini #更具php安装目录而定3. 重启web service如果是apache: service httpd restart方法二&#xff1a;php 5.36安装目录&#xf…

仿余额宝数字跳动效果 TextCounter

1、TextCounter 效果 2、TextCounter 说明 每次打开余额宝第一件事情就去看看有多少钱&#xff0c;最炫的就是看着钱在跳动相当的舒服&#xff0c;今天放出这个效果。 温馨提示&#xff1a;支持的Android版本最低的是Android 4.0.0 IceCreamSandwich &#xff08; API等级14 &a…

年仅 16 岁的黑客少年,竟是搅乱 IT 巨头的幕后主使?

整理 | 郑丽媛出品 | CSDN近来&#xff0c;黑客组织 Lapsus$ 活跃在各大科技网站&#xff1a;窃取英伟达近 1TB 的数据、泄露三星近 190GB 的机密数据、公布微软 Bing 和 Cortana 源码…不同于大部分黑客组织&#xff0c;Lapsus$ 没有刻意隐藏自己&#xff0c;反而行事非常高调…

使用硬盘,安装双系统,Win7+CentOS

我用那个U盘装了很多次都不行&#xff0c;都是说找不到文件。最后就找了一篇博客看如何安装双系统&#xff0c;最后发现原来可以用硬盘安装的。经过5个多小时终于完成了。^-^。 1.首先是分区&#xff0c;可以使用Window7自带的磁盘管理程序进行分区。&#xff08;PS 我是用Cent…

Linux 文件系统剖析

Linux 文件系统剖析 按照分层结构讨论 Linux 文件系统 M. Tim Jones, 顾问工程师, Emulex Corp. 简介&#xff1a; 在文件系统方面&#xff0c;Linux 可以算得上操作系统中的 “瑞士军刀”。Linux 支持许多种文件系统&#xff0c;从日志型 文件系统到集群文件系统和加密文件系统…

Docker构建Nginx+Tomcat动静分离架构

随着主流Nginx WEB服务器的发展&#xff0c;现在基于Nginx的WEB服务器已广泛应用于各大互联网企业。今天我们来使用docker构建我们的LinuxNginxTomcat动静分离服务器。1) 启动docker镜像查看当前系统存在的镜像&#xff0c;我这里为CentOS6.6&#xff0c;大家可以参考我第一…

硬核!Python 四种变量的代码对象和反汇编分析

作者 | 大奎整理 | 阳哥来源丨Python数据之道在Python基础的学习过程中&#xff0c;对变量和参数的理解有助于我们从更基础层面了解Python语言的运行。在这个过程中&#xff0c;还是有不少冷门和细节的地方需要进一步熟悉。今天我们来分享Python四种变量的代码对象和反汇编分析…

Python--数据存储:pickle模块的使用讲解

在机器学习中&#xff0c;我们常常需要把训练好的模型存储起来&#xff0c;这样在进行决策时直接将模型读出&#xff0c;而不需要重新训练模型&#xff0c;这样就大大节约了时间。Python提供的pickle模块就很好地解决了这个问题&#xff0c;它可以序列化对象并保存到磁盘中&…

Linux虚拟内存和物理内存精华【美】

原文地址&#xff1a; 《Playing with Virtual Memory》 http://www.snailinaturtleneck.com/blog/2011/08/30/playing-with-virtual-memory/ 扩展阅读&#xff1a; 《Understanding Memory》 http://www.ualberta.ca/CNS/RESEARCH/LinuxClusters/mem.html 《Understanding Vir…

留不住客户?该从你的系统上找找原因了

本篇文章暨 CSDN《中国 101 计划》系列数字化转型场景之一。 《中国 101 计划——探索企业数字化发展新生态》为 CSDN 联合《新程序员》、GitCode.net 开源代码仓共同策划推出的系列活动&#xff0c;寻访一百零一个数字化转型场景&#xff0c;聚合呈现并开通评选通道&#xff0…

系统配置文件备份比较

客户的系统出各种问题&#xff0c;这次出了问题整整一天都没找出原因&#xff0c;都红脸了&#xff0c;最后发现是系统配置文件被改掉了&#xff0c;简直不能忍&#xff0c;所以写了这个脚本&#xff0c;放到定时任务里面&#xff0c;每天备份比较配置文件import difflib impor…

RPC是什么?为什么要学习RPC?

随着近几年分布式、微服务架构的火热&#xff0c;RPC在开发工作中使用的越来越多&#xff0c;也变的越来越重要。 今天我们来看RPC是什么&#xff0c;为什么要了解RPC,通过学习RPC我们能掌握什么内容&#xff1f; 什么是「RPC」 RPC 全称 Remote Procedure Call, wikipedia的部…

Lua学习笔记6:C++和Lua的相互调用

曾经一直用C写代码。话说近期刚换工作。项目组中的是cocos2dx-lua&#xff0c;各种被虐的非常慘啊有木有。新建cocos2dx-lua项目。打开class能够发现&#xff0c;事实上就是C项目啦&#xff0c;只是为什么仅仅有一类Appdelegate类呢&#xff1f;哈哈,我相信聪明的你一定猜到了&…

Redis消息通知系统的实现

Redis消息通知系统的实现Posted on 2012-02-29by 老王 http://huoding.com/2012/02/29/146最近忙着用Redis实现一个消息通知系统&#xff0c;今天大概总结了一下技术细节&#xff0c;其中演示代码如果没有特殊说明&#xff0c;使用的都是PhpRedis扩展来实现的。内存比如要推送一…

用 Python 实现答题卡识别!

作者 | 棒子胡豆来源丨CSDN博客答题卡素材图片&#xff1a;思路读入图片&#xff0c;做一些预处理工作。进行轮廓检测&#xff0c;然后找到该图片最大的轮廓&#xff0c;就是答题卡部分。进行透视变换&#xff0c;以去除除答题卡外的多余部分&#xff0c;并且可以对答题卡进行校…

Confluence 6 计划任务

管理员控制台能够允许你对 Confluence 运行的计划任务进行计划的调整&#xff0c;这些计划任务将会按照你的调整按时执行。可以按照计划执行的任务如下&#xff1a; Confluence 站点备份存储优化任务&#xff0c;清理 Confluence 的临时目录中的文件和缓存索引优化任务&#xf…

PHP共享内存段

在asp.net和java中都有共享内存&#xff0c;php除了可以使用Memcached等方式变通以外其实php也是支持共享内存的&#xff01;需要安装扩展shmop 找到php安装源文件目录# cd /usr/local/php-5.4.0/ext/shmop # /usr/local/php/bin/phpize # ./configure --with-php-config/usr/l…

马尔科夫随机场的基本概念

1、随机过程&#xff1a; 描写叙述某个空间上粒子的随机运动过程的一种方法。它是一连串随机事件动态关系的定量描写叙述。随机过程与其他数学分支&#xff0c;如微分方程、复变函数等有密切联系。是自然科学、project科学及社会科学等领域研究随机现象的重要工具。 2、马尔科夫…

从事了两年 AI 研究,我学到了什么?

作者 | Tom Silver译者 | 弯月出品 | CSDN我从事人工智能研究的工作已经有两年了&#xff0c;有朋友问我都学到了什么&#xff0c;所以我想借本文分享一些迄今为止积累的经验教训。我将在本文中分享一些常见的经历&#xff0c;还会讨论相对具体的人工智能行业技巧。希望对大家能…

Windows server 2008普通用户不能远程登录问题

1、查登录权限 如果文件服务器没有为用户授权&#xff0c;那么用户自然就不能远程登录服务器系统了&#xff0c;为此笔者决定先仔细检查一下文件服务器系统是否为自己使用的登录账号&#xff0c;授予了远程登录权限。在进行这种检查时&#xff0c;笔者先是在文件服务器本地以系…

面向小白的最全 Python 可视化教程,超全的!

作者 | 俊欣来源丨关于数据分析与可视化今天小编总结归纳了若干个常用的可视化图表&#xff0c;并且通过调用plotly、matplotlib、altair、bokeh和seaborn等模块来分别绘制这些常用的可视化图表&#xff0c;最后无论是绘制可视化的代码&#xff0c;还是会指出来的结果都会通过调…

Atitit.文件搜索工具 attilax 总结

Atitit.文件搜索工具 attilax 总结 1. 指定目录按照体积大小精确搜索1 1.1. File Seeker 4.5 版本的可以&#xff0c;3.5版本的不行。。1 2. 按照文件内容搜索1 2.1. File Seeker2 2.2. Notepad2 2.3. FileLocator Pro 是一款专业的文件搜索软件&#xff0c;2 2.4. 百度硬盘搜索…

ulimit -SHn 65535 含义

linux下用ulimit设置连接数最大值&#xff0c;默认是1024.在高负载下要设置为更高&#xff0c;但最高只能为65535. ulimit只能做临时修改&#xff0c;重启后失效。可以加入ulimit -SHn 65535到 /etc/rc.local 每次启动启用。终极解除 Linux 系统的最大进程数和最大文件打开数限…

5.7-基于Binlog+Position的复制搭建

基本环境 MasterSlaveMySQL版本MySQL-5.7.16-X86_64MySQL-5.7.16-X86_64IP192.168.56.156192.168.56.157Port33063306数据库环境的部署&#xff1a;两边安装好相同的数据库软件&#xff0c;初始化&#xff0c;可以启动起来。检查事项&#xff1a;两边防火墙是否开启&#xff0c…

PHP消息队列httpsqs安装与使用无错版

项目网址&#xff1a;http://code.google.com/p/httpsqs/使用文档&#xff1a;http://blog.s135.com/httpsqs/ 说明&#xff1a;由于需要安装的东西有些多&#xff0c;原文可能写的有些简略&#xff0c;所以适当补充了1.安装libevent-2.0.12-stable.tar.gzwget http://httpsqs.…

Windows Server 2012 系统群集

Windows Server 2012 系统群集本次将测试Windows Server 2012 系统群集功能。实验环境&#xff1a;4台服务器都为Windows Server 2012 DataCenter操作系统SRV2012服务器安装iSCSI目标服务器角色并配置2块虚拟磁盘给两台群集服务器共享使用。群集服务器安装群集功能&#xff0c;…

Python 中最强大的错误重试库

作者 | 费弗里来源丨Python大数据分析1 简介我们在编写程序尤其是与网络请求相关的程序&#xff0c;如调用web接口、运行网络爬虫等任务时&#xff0c;经常会遇到一些偶然发生的请求失败的状况&#xff0c;这种时候如果我们仅仅简单的捕捉错误然后跳过对应任务&#xff0c;肯定…

Spring Cloud云架构 - SSO单点登录之OAuth2.0登录流程(2)

上一篇是站在巨人的肩膀上去研究OAuth2.0&#xff0c;也是为了快速帮助大家认识OAuth2.0&#xff0c;闲话少说&#xff0c;我根据框架中OAuth2.0的使用总结&#xff0c;画了一个简单的流程图&#xff08;根据用户名密码实现OAuth2.0的登录认证&#xff09;&#xff1a; 上面的图…