SRETAN (sretan.pas/c/cpp)

题目描述

4和7是幸运数字,输入k,输出第k个只含有4和7的数。

输入格式

一行一个数k

输出格式

一行一个数表示答案

样例输入

3

样例输出

44

数据范围与约定

1 <= k <= 10^9

分析:

个位上有2个,十位上有4个,百位上有8个…… 找出规律:2^n,我们要分析第n个是在哪一位上,当前面所有方案数大于k时,可以在当前位上查找。将当前位数div 2;若k大于它,则输出7,否则输出4,直到div 2=1时,输出所有的数。

代码实现:

program exam;

var

i,j:longint;

k,t,s1,a2:int64;

function
f(a,b:int64):int64;

var

t,y:int64;

begin

t:=1;

y:=a;

while b<>0 do

begin

if b and 1=1 then

t:=t*y;

y:=y*y;

b:=b shr 1;

end;

exit(t);

end;

procedure make(x,y:int64);

begin

if x div 2=1 then

begin

if y=2 then

write(7);

if y=1 then

write(4);

close(input);

close(output);

halt; 注意,一定要halt;如果exit,会继续递归,会产生多余的数。

end;

x:=x div 2;

if y>x then

begin

write(7);

y:=y-x;

make(x,y);

end;

if y<=x then

begin

write(4);

make(x,y);

end;

end;

begin

assign(input,'sretan.in');

reset(input);

assign(output,'sretan.out');

rewrite(output);

readln(k);

for i:=1 to 60 do

begin

t:=f(2,i+1)-2;

if t>=k then

begin

s1:=f(2,i)-2;

k:=k-s1;

a2:=f(2,i);

make(a2,k);

end;

if t>k then

break;

end;

close(input);

close(output);

end.

SRETAN的更多相关文章

随机推荐

  1. jquery 序列化

    //生成发件人Json信息 function buildSenderInfoJson() { var sendName = $("#SendName").val(); var se ...

  2. 用Java写算法之归并排序

    转自:http://flyingcat2013.blog.51cto.com/7061638/1281026 前面的三种排序算法(冒泡排序,选择排序,插入排序)在平均情况下均为O(n^2)复杂度,在处 ...

  3. MongoDB导入(mongoimport)-导出(mongoexport)工具使用

    1.导出工具-mongoexport Mongodb中的mongoexport工具可以把一个collection导出为JSON格式或者CSV格式文件. (1).导出为JSON文件 /opt/mongo ...

  4. Breakpoint is not hit

    新拿到一个Silverlight项目,能够正常运行,但是一旦运行起来,断点处由实心点变成了空心的,并警告:The breakpoint will not currently be hit. No sy ...

  5. python安装tkinter

    python2安装tkinter sudo apt-get install python-tk python3 安装tkinter sudo apt-get install python3-tk

  6. Java Sha1 加密算法

    //下面四个import放在类名前面 包名后面 //import java.io.UnsupportedEncodingException; //import java.security.Messag ...

  7. [2015hdu多校联赛补题]hdu5301 Buildings

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5301 题目大意:给你一块由1x1方格组成的矩形区域,其中有且仅有一个坏块,现在你要在上面建矩形的房子, ...

  8. Android加载SD卡目录,文件夹遍历,图片设置,设置文件对应打开方式等

    此案例主要说的是Android使用GridView加载SD卡下所有目录,文件夹多层遍历,文件图标修改,设置文件对应打开方式等功能. 如图: 代码: public class GridViewFile ...

  9. Struts2理解--动态方法和method属性及通配符_默认Action

    众所周知,默认条件下,在浏览器输入indexAction!execute.action,便会执行indexAction类里的execute方法,这样虽然方便,但可能带来安全隐患,通过url可以执行Ac ...

  10. 怎样从altera下载软件与器件库

    首先要注册一个帐号,否则是不能下载的. step1:进入support->download 这是页面下方的显示,可以选择想要安装的Quartus版本以及该版本支持的器件.这里以16.0标准版为例 ...