题目链接:

http://poj.org/problem?id=3899

题目意思:

求给定区间内,只含4、7的数的个数以及通过反转后在该区间内的个数和。

解题思路:

模拟+数学。

代码解释的很详细,请看代码。

#include<iostream>
#include<cmath>
#include<cstdio>
#include<cstdlib>
#include<string>
#include<cstring>
#include<algorithm>
#include<vector>
#include<map>
#include<set>
#include<stack>
#include<list>
#include<queue>
#define eps 1e-6
#define INF 0x1f1f1f1f
#define PI acos(-1.0)
#define ll __int64
#define lson l,m,(rt<<1)
#define rson m+1,r,(rt<<1)|1
using namespace std; /*
freopen("data.in","r",stdin);
freopen("data.out","w",stdout);
*/
char A[50],B[50];
//g1(a,b,len) 表示1-a中后缀为b的lucky数,其中len是b的长度
//g2(a,b)表示1-a中反转后大于b的lucky数
//A-B 之间的lucky数个数为 g1(B,0,0)-g1(A-1,0,0)
//反转后在A-B 之间的lucky数为 g2(A,A)-g2(A,B)+g2(B,B)-g2(A,B) ll g1(char * a,char * b,int len)
{
int alen=strlen(a);
ll res=0;
bool ism=false; for(int i=0;i<len;i++) //比较a的后len位与b的大小,>=
{
int j=i+alen-len;
if(a[j]>b[i])
break;
else if(a[j]<b[i])
{
ism=true;
break;
}
}
if(len==0) //先算出低于alen位的总的lucky数
{
for(int i=1;i<alen;i++)
res+=(ll)1<<i; //i位的话一共有2^i个lucky数
}//如果len!=0 那么前面的m位中也有1-m,这种情况好像没考虑啊
int m=alen-len; //计算与a位数相同lucky数
int i;
for(i=0;i<m;i++) //一位一位从前往后考虑
{
if(a[i]>'7') //4和7都可以
{
res+=(ll)1<<(m-i);
break;
}
else if(a[i]=='7') //4一定可以,7再往后计算
res+=(ll)1<<(m-i-1);//把是4的情况计算清楚,后面就是7的情况
else if(a[i]>'4'&&a[i]<'7')
{
res+=(ll)1<<(m-i-1); //放4的情况,后面可以任意
break;
}
else if(a[i]<'4')
break;
}
if((i==m)&&!ism) //计算临界情况
res++;
return res;
} ll g2(char * a,char * b) //1-a之间,反转后大于b的lucky数
{ //b的长度肯定要>=a的长度
int alen=strlen(a);
char tmp[50],*last=&tmp[49]; //从后往前
ll res=0; for(int i=0;i<alen;i++)
{
if(b[i]>'7') //高位已经超过7了,不可能超过它了
break ;
else if(b[i]=='7') //边界情况
*(last--)='7';
else if(b[i]>'4'&&b[i]<'7') //只要满足这
{
*last='7'; //只要把后面的这一位置成7,前面的可以任意了
res+=g1(a,last,i+1);
break;
}
else if(b[i]=='4')
{
*last='7';
res+=g1(a,last,i+1); //把这位放7,前面的就任意了
*(last--)='4'; //然后把它放4作为临界情况
}
else
{
*last='7'; //后面放7,前面就任意了
res+=g1(a,last,i+1);
*last='4'; //后面放4,前面就任意了
res+=g1(a,last,i+1);
break;
}
}
//因为是算大于的情况,临界情况就不用考虑了
return res;
} int main()
{
int t; char aa[4]="999",bb[2]="7";
printf("%I64d\n",g1(aa,bb,1)); scanf("%d",&t);
while(t--)
{
scanf("%s%s",A,B);
int lea=strlen(A),leb=strlen(B); if(A[lea-1]!='0')
--A[lea-1]; //是零的话就无所谓了
ll ans=0;
ans+=(g1(B,NULL,0)-g1(A,NULL,0)+g2(A,A)+g2(B,B));
if(lea==leb)
ans-=(2*g2(A,B));
printf("%I64d\n",ans); }
return 0;
}

poj-3899-The Lucky Numbers 模拟+数学的更多相关文章

  1. HDU 5676 ztr loves lucky numbers (模拟)

    ztr loves lucky numbers 题目链接: http://acm.hust.edu.cn/vjudge/contest/121332#problem/I Description ztr ...

  2. codeforces 630C Lucky Numbers

    C. Lucky Numbers time limit per test 0.5 seconds memory limit per test 64 megabytes input standard i ...

  3. hdu 5676 ztr loves lucky numbers(dfs+离线)

    Problem Description ztr loves lucky numbers. Everybody knows that positive integers are lucky if the ...

  4. codeforces 630C - Lucky Numbers 递推思路

    630C - Lucky Numbers 题目大意: 给定数字位数,且这个数字只能由7和8组成,问有多少种组合的可能性 思路: 假设为1位,只有7和8:两位的时候,除了77,78,87,88之外还哇哦 ...

  5. hdu 5676 ztr loves lucky numbers 打表+二分

    ztr loves lucky numbers Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/ ...

  6. ZCMU 2177 Lucky Numbers (easy)

    传送门: http://acm.zcmu.edu.cn/JudgeOnline/problem.php?id=2177 2177: Lucky Numbers (easy) 时间限制: 2 Sec   ...

  7. hdu-5676 ztr loves lucky numbers(乱搞题)

    题目链接: ztr loves lucky numbers  Time Limit: 2000/1000 MS (Java/Others)  Memory Limit: 65536/65536 K ( ...

  8. C - Lucky Numbers (easy)

    Problem description Petya loves lucky numbers. Everybody knows that positive integers are lucky if t ...

  9. Codeforces Round #160 (Div. 2)---A. Roma and Lucky Numbers

    Roma and Lucky Numbers time limit per test 1 second memory limit per test 256 megabytes input standa ...

随机推荐

  1. js大小写锁判断

    <html> <head> <title>CapsLock Demo</title> <script src="http://ajax. ...

  2. android 支持分组和联系人展示的一个小样例

    先看效果图: 要实现这个效果,activity必须实现ExpandableListActivity @Override public void onCreate(Bundle savedInstanc ...

  3. Java输入输出流(1)

    1.什么是IO Java中I/O操作主要是指使用Java进行输入,输出操作. Java全部的I/O机制都是基于数据流进行输入输出,这些数据流表示了字符或者字节数据的流动序列.Java的I/O流提供了读 ...

  4. 【转】windows上自动设置java环境变量的脚本

    转载:http://www.cnblogs.com/flowwind/p/4066146.html 近期打算学习安卓开发,于是乎要准备java开发环境,安装好jdk后,就要 设置java环境变量,ja ...

  5. spring多数据源的配置

    C3P0和DBCP的区别 C3P0是一个开源的JDBC连接池,它实现了数据源和JNDI绑定,支持JDBC3规范和JDBC2的标准扩展.目前使用它的开源项目有Hibernate,Spring等.   d ...

  6. 用pc浏览器打开手机页面

    原理是仿造http包头,下面已chrome为例. 方法:运行->输入如下手机操作系统对应的代码即可. 安卓: chrome.exe --user-agent="Mozilla/5.0 ...

  7. php 自己写的好看的分页类

    自己写的一个分页类 ,不是很完整,个别没有做验证,但可以使用,分页效果见文章底部.除了链接数据库的代码没有粘贴上来,其他的都粘贴了.供学习使用- <?php /** * Created by P ...

  8. [转载]MySql常用命令总结

    原文:http://www.php100.com/html/webkaifa/database/Mysql/2009/0910/3288.html1:使用SHOW语句找出在服务器上当前存在什么数据库: ...

  9. 函数重载不仅仅是看其参数,还要看是否有const修饰

    比如QString有两个函数,可以堂而皇之的存在,原因就在于有了const修饰以后,编译器不把两个函数当作同一个函数名了: QChar * data() const QChar * data() co ...

  10. 关于map

    java为数据结构中的映射定义了一个接口java.util.Map;它有四个实现类,分别是HashMap Hashtable LinkedHashMap 和TreeMap. Map主要用于存储健值对, ...