EOJ 3031 二进制倒置
题目描述
给定一个整数 n(0≤n≤10100)、将 n 的 334 位二进制表示形式(不包括开头可能的值为 0 的位,n=0 表示为 1 位 0)前后倒置,输出倒置后的二进制数对应的整数。
例如:n=10,其二进制表示为 (330 个 0)1010,倒置后为 0101,对应输出就是 5。
Input
第 1 行:一个整数 T (1≤T≤10) 为问题数。
接下来共 T 行整数,对应每个问题有 1 行,表示 n。
Output
对于每个问题,输出一行问题的编号(0 开始编号,格式:case #0: 等)。
然后对应每个问题在一行中输出结果。
#include <stdio.h>
#include <stdlib.h>
#define END 10
void init(int *n)
{
char c;int i=;
while((c=getchar())!='\n')
{
n[i]=c-'';
i++;
}
n[i]=END;
}//用getchar()将大整数逐位读入数组,以换行符为结束标志
void multiout(int* out)//将数组表示的整数*2
{
int *p=out,carry,plus=;
while()
{
if(*p==-)//乘法结束
{
if(p-out==)
{
*p=;
return;
}
else if(plus==)
*p=plus;
return;
}
carry=*p*+plus; 原位置*2+进位
*p=carry%;
plus=carry/;
p++;
} }
int addout(int* out,int get)
{
int* p=out;
if(get==) return; else
{ *p=*p+;
while(*p==)
{
*p=;
(*(++p))++;
}
}//46-51行其实不需要,任何数×2之后,各位必定是偶数,加1不会引起进位 } int main()
{
int cas;scanf("%d\n",&cas);
for(int m=;m<cas;m++)
{
int BIGINT[],bin[],pos=,binpos;
init(BIGINT);//读入整数
//以下开始求整数的二进制形式,并存放在二进制数组中,显然,存放的时候已经是倒序了。
//pos是整数数组的最高位,binpos记录二进制数组何时结束
//以整数5432为例
for(binpos=;BIGINT[pos]!=END;binpos++) //一直计算到整数为0(pos达到END处) {
int rmd=,divd; //
for(int i=pos;BIGINT[i]!=END;i++) // i=0 i=1 i=2 i=3
{ //
divd=rmd*+BIGINT[i]; // divd=5 divd=14 divd=3 divd=12
rmd=divd%; // rmd=5除以2余1 rmd=0 rmd=1 rmd=0
BIGINT[i]=divd/; // 原5的位置除2后为2 原4位置为7 原3位置为1 原2位置为6
} //可以看到,一次运算,5432除2得2716,余0,将0存入二进制数组,并更新binpos位置
bin[binpos]=rmd; //
if(BIGINT[pos]==) pos++; //2716/2=1358,1358/2=678; 此时BIGINT[pos]=0,pos更新,下次计算时,便从6开始了。
} //
bin[binpos]=END; //标记二进制数组结束位置
int out[],ppos=;out[]=bin[];
for(int i=;i<;i++) out[i]=-;
for(int i=;bin[i]!=END;i++) //二进制转十进制,从最高位开始*2+后一位,注意这个数组是倒序了的
{
multiout(out);
addout(out,bin[i]);
}
for(;out[ppos+]!=-;ppos++); printf("case #%d:\n",m);
for(ppos;ppos>=;ppos--)
printf("%d",out[ppos]);
printf("\n"); }
return 0; }
具体分析看注释。
这题应该算是一个大数的题吧,long long类型最大值在1018,因此用数组保存数据。
EOJ 3031 二进制倒置的更多相关文章
- OJ题解记录计划
		
容错声明: ①题目选自https://acm.ecnu.edu.cn/,不再检查题目删改情况 ②所有代码仅代表个人AC提交,不保证解法无误 E0001 A+B Problem First AC: 2 ...
 - EOJ Monthly 2019.2 题解(B、D、F)
		
EOJ Monthly 2019.2 题解(B.D.F) 官方题解:https://acm.ecnu.edu.cn/blog/entry/320/ B. 解题 单测试点时限: 2.0 秒 内存限制: ...
 - 二进制加法Java实现
		
二进制整数的Java实现 任意两个二进制数(不论在什么位置)相加,只可能出现4种情况.它们是: 0+0=0 1+0=0+1=1 1+1=10=0+向高一位的进位1 1+1+1=11=1+向高一位的进位 ...
 - linux二进制/十六进制日志文件如何查看和编辑
		
使用cat查看二进制,显示乱码 [root@localhost ~]# cat /var/log/wtmp ~~~reboot3.10.0-514.el7.x86_64 �YO#5~~~runleve ...
 - # Leetcode 67:Add Binary(二进制求和)
		
Leetcode 67:Add Binary(二进制求和) (python.java) Given two binary strings, return their sum (also a binar ...
 - 使用struct处理二进制
		
有的时候需要用python处理二进制数据,比如,存取文件.socket操作时.这时候,可以使用python的struct模块来完成. struct模块中最重要的三个函数是pack(), unpack( ...
 - 如何开启MySQL 5.7.12 的二进制日志
		
1. 打开/etc下的my.cnf文件 2. 编辑它,添加内容: log_bin=binary-log #二进制日志的文件名 server_id=1 #必须指定server_id,这是MySQL ...
 - 【.net 深呼吸】使用二进制格式来压缩XML文档
		
在相当多的情况下,咱们写入XML文件默认是使用文本格式来写入的,如果XML内容是通过网络传输,或者希望节省空间,特别是对于XML文档较大的情况,是得考虑尽可能地压缩XML文件的大小. XmlDicti ...
 - Javascript的二进制数据处理学习 ——nodejs环境和浏览器环境分别分析
		
以前用JavaScript主要是处理常规的数字.字符串.数组对象等数据,基本没有试过用JavaScript处理二进制数据块,最近的项目中涉及到这方面的东西,就花一段时间学了下这方面的API,在此总结一 ...
 
随机推荐
- VmWare 安装 Centos
			
VMware CentOS7 的 ISO 文件 方法/步骤 1 打开虚拟机软件“VMware”,选择“创建新的虚拟机”: 2 选择“自定义(高级)”选项,点击“下一步”: 3 在“硬件兼容性”处选 ...
 - [转]常用Git命令清单
			
原文地址:http://www.ruanyifeng.com/blog/2015/12/git-cheat-sheet.html 作者: 阮一峰 日期: 2015年12月 9日 我每天使用 Git , ...
 - Object.assign和序列/反序列
			
Object.assign let testObj = { a:[1,2,4], b:{ name:'ls', school:['huf','yelu'], parent:{ father:'lili ...
 - [转载]windows下github 出现Permission denied (publickey).解决方法
			
今天在学习github的时候遇到了一些问题,然后爬了一会,找到了解决方法记录下来,以防忘记,当然能帮助别人最好啦! github教科书传送门:http://www.liaoxuefeng.com/ ...
 - [kernel学习]----好文章梳理
			
内存相关 Linux的内存回收和交换 Linux内核分析:页回收导致的cpu load瞬间飙高的问题分析与思考 认识Linux物理内存回收机制 认真分析mmap:是什么 为什么 怎么用 kernel排 ...
 - SSL/TLS 加密新纪元 - Let's Encrypt
			
转自: https://linux.cn/article-6565-1.html SSL/TLS 加密新纪元 - Let's Encrypt 根据 Let's Encrypt 官方博客消息,Let's ...
 - 类型信息、异常、I/O流(day11)
			
二十三 运行时的类型信息 typeid运算符 #include <typeinfo> typeid(类型/对象) )返回typeinfo的对象,用于描述类型信息. )在typeinfo类中 ...
 - NOIP2017总结与反思
			
手动博客搬家: 本文发表于20180213 00:01:05, 原地址https://blog.csdn.net/suncongbo/article/details/79319556 //由于12月生 ...
 - zuul 路由网关
			
一.阐述 Zuul 包含了对请求的路由和过滤两个主要的功能: 路由功能:负责将外部请求转发到具体的微服务实例上,是实现外部访问统一入口的基础: 滤器功能:负责对请求的处理过程干预,是实现请求校验.服务 ...
 - 第三次训练 密码acmore
			
网站:CSUST7月23号 A题:大意是:一个N多边形,用红,绿,蓝三色给定点上色,要求划分成顶点颜色不同的三角形. 解析: 这道题是黑书上分治法的例题,还是比较巧的. 首先很容易发现当某种颜色的点只 ...