2017.8.9测试 题一 17倍
来源:互联网 发布:alchemy软件 编辑:程序博客网 时间:2024/06/01 09:16
17倍
(Times17)
题目:
在了解做软件开发可能赚很多的钱之后,农夫约翰也开了一家小的软件公司为客户写程序。约翰的第一个任务对他来说看起来相当简单:输入一个数N,然后输出17*N的值。但是现在,客户又变更了一个条件,输入的N是一个二进制数,输出的值也要是二进制表示的。
问题描述:
现在请帮助约翰完成这个任务。
输入格式:
一个二进制表示的数N。
输出格式:
二进制表示的17N。
输入输出样例:
times17.in
10110111
times17.out
110000100111
数据范围:
N的位数不超过1000位。
说明:
10110111相当于十进制的183,于是183*17=3111,二进制形式是110000100111 。
题解:本题的17倍可以用乘法分配律分配成(16+1),16的二进制是10000,1的二进制就是1,所以就是s*10000(向前移4位)+s就行啦
var a,b,c:array[0..100000]of longint; s,ss:ansistring; len1,len2,len3,i,t,g:longint;begin read(s); len1:=length(s); for i:=1 to len1 do val(s[i],a[len1-i+1]); ss:=s+'0000';//s*10000后的数 len2:=len1+4;//向前移了4位,所以长度+4 for i:=1 to len2 do val(ss[i],b[len2-i+1]); i:=1; while (i<=len1) or (i<=len2) or (i<=len3)do//二进制的高精度加法~ begin if len3<i then len3:=i; t:=a[i]+b[i]+g; c[i]:=t mod 2; g:=t div 2; if g>=1 then inc(len3); inc(i); end; for i:=len3 downto 1 do write(c[i]);end.
阅读全文
1 0
- 2017.8.9测试 题一 17倍
- 2017.8.9测试 题一 17倍
- 17倍
- 17倍(Times17)
- 2017.8.7测试 题一 小游戏
- 2017.8.8测试 题一 分数拆分
- IE10的市场占有率扩充了一倍
- 函数将数组扩大一倍
- 软件测试题一
- oracle测试题一
- 8.9 17倍times17 2492
- SM2 K倍点测试中间数据 问题
- 超越spark性能300倍的性能测试
- ThinkPHP胜出Laravel 近4倍,主流框架性能测试
- iPad 运行cocos2d的2倍游戏时,显示变成一倍,且显示在左下角
- [oc实战练习一]2倍图与3倍图
- CocoaChina测试题 小记一
- php测试题(一)
- 【SQL Server学习笔记】11:视图和公用表表达式
- AH00558: httpd: Could not reliably determine the server's fully qualified domain name, using localh
- javascript中sort()函数的原理
- 【练习】PTA基础编程题目集
- 2017.9.8——字符串中的\0
- 2017.8.9测试 题一 17倍
- NOIP2015-Junior_sum_Solve.md
- WINDOWS系统电源管理:休眠,睡眠,待机,关机
- Java集合类List、Set、Map
- linux命令--查看文件文件命令(more、cat、less)
- HTTP网络通信--Android--async-http框架库
- P2525 Uim的情人节礼物·其之壱
- HDU 4135 Co-prime (容斥)
- unity shader学习 简单的顶点-片段 shader