hdu 5969 最大的位或
最大的位或
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)
Total Submission(s): 655 Accepted Submission(s): 293
Problem Description
B君和G君聊天的时候想到了如下的问题。
给定自然数l和r ,选取2个整数x,y满足l <= x <= y <= r ,使得x|y最大。
其中|表示按位或,即C、 C++、 Java中的|运算。
Input
包含至多10001组测试数据。
第一行有一个正整数,表示数据的组数。
接下来每一行表示一组数据,包含两个整数l,r。
保证 0 <= l <= r <= 1018。
Output
对于每组数据输出一行,表示最大的位或。
Sample Input
Sample Output

#include <stdio.h>
#include <string.h> typedef long long LL; LL l,r,Max;
char bit_l[];
char bit_r[];
char temp[]; LL StrToNum(char s[])//二进制字符变数字
{
int len=strlen(s);
LL ans=,res=;
for (int i=len-;i>=;i--)
{
if (s[i]=='')
ans+=res;
res*=;
}
return ans;
} void NumToStr(LL x)//数字变二进制字符串
{
if (x==)
{
temp[]='';
temp[]='\0';
return ;
}
char s[];
int pos=;
while (x!=)
{
int tt=x%;
if (tt==)
s[pos++]='';
else if (tt==)
s[pos++]='';
x/=;
}
s[pos]='\0';
int i;
for (i=;i<pos;i++)
temp[i]=s[pos--i];
temp[i]='\0';
} int main()
{
int i,j,t;
char test[];
scanf("%d",&t);
while (t--)
{
Max=-;
scanf("%I64d%I64d",&l,&r);
if (l==r)
{
printf("%lld\n",l|r);
continue;
}
NumToStr(l);
strcpy(bit_l,temp);
NumToStr(r);
strcpy(bit_r,temp); strcpy(test,bit_r);
int len_l=strlen(bit_l);
int len_r=strlen(bit_r);
for (i=;i<len_r-len_l;i++)
{
test[i]='';
}
for (j=;j<=len_l;j++)
{
test[i++]=bit_l[j];
}
strcpy(bit_l,test);
for (i=;i<len_r;i++)
{
if (bit_l[i]==''||bit_r[i]=='')
test[i]='';
else
test[i]='';
}
test[i]='\0';
LL res;
res=StrToNum(test);
if (res>Max) Max=res;
//printf("l : %s\n",bit_l);
//printf("r : %s\n",bit_r);
//printf("t : %s\n",test);
int k=;
while (bit_l[k]==bit_r[k]) k++;
k++;
for (i=k;i<len_r;i++)
{
res=StrToNum(test);
if (res>Max) Max=res;
if (bit_l[i]==''&&bit_r[i]=='')
{
test[i]='';
res=StrToNum(test);
if (res>Max)
Max=res;
}
}
printf("%I64d\n",Max);
}
return ;
}
hdu 5969 最大的位或的更多相关文章
- HDU 5969 最大的位或 (思维,贪心)
HDU 5969 最大的位或 题目大意 B君和G君聊天的时候想到了如下的问题. 给定自然数\(l\)和\(r\) ,选取\(2\)个整数\(x,y\)满足\(l <= x <= y < ...
- HDU 5969 最大的位或 —— 贪心 + 二进制的理解
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5969 最大的位或 Time Limit: 2000/1000 MS (Java/Others) ...
- HDU 5969 最大的位或 【贪心】 (2016年中国大学生程序设计竞赛(合肥))
最大的位或 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Problem De ...
- HDU - 5969 最大的位或 想法题
http://acm.hdu.edu.cn/showproblem.php?pid=5969 (合肥)区域赛签到题...orz 题意:给你l,r,求x|y的max,x,y满足l<=x<=y ...
- HDU 5969 最大的位或【贪心/按位或/思维】
链接 最大的位或 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) Total Subm ...
- hdu 5969 最大的位或(贪心)
Problem Description B君和G君聊天的时候想到了如下的问题.给定自然数l和r ,选取2个整数x,y满足l <= x <= y <= r ,使得x|y最大.其中|表示 ...
- HDU 5969 最大的位或【贪心】
题目 B君和G君聊天的时候想到了如下的问题. 给定自然数l和r ,选取2个整数x,y满足l <= x <= y <= r ,使得x|y最大. 其中|表示按位或,即C. C++. Ja ...
- HDU 5969 最大的位或 题解
题目 B君和G君聊天的时候想到了如下的问题. 给定自然数l和r ,选取2个整数\(x,y\)满足\(l <= x <= y <= r\),使得\(x|y\)最大. 其中\(|\)表示 ...
- 【贪心算法】HDU 5969 最大的位或
题目内容 Vjudge链接 给出一个闭区间,找该区间内两个数,使这两个数的按位或最大. 输入格式 包含至多\(10001\)组测试数据. 第一行有一个正整数,表示数据的组数. 接下来每一行表示一组数据 ...
随机推荐
- Ubuntu14.04进行配置符号链接arm-2009q3.tar.bz2
进入系统终端:cd /usr/local/ 创建文件夹arm:并进去arm,将winshare共享文件夹里面的文件/arm-2009q3复制到arm文件夹中; tar -jxvf arm-2009q ...
- ASP.NET MVC学习---(二)EF文件结构
之前已经简单的介绍过ORM框架和EF 也了解了EF的种种优点 那么这个EF到底长啥样子都还没见过呢 别着急 接下来,科学教育频道--走近科学 带你走进EF的内心世界~ 那么接下来就是~ 等等等等... ...
- Linux学习之一-从三个重要人物的故事和一张思维导图说起
Linux是一套自由加开放源代码的类Unix操作系统,诞生于1991年10月5日(第一次正式向外公布),由芬兰学生Linus Torvalds和后来陆续加入的众多爱好者共同开发完成. Linux是一个 ...
- tomcat修改默认访问首页
找到conf下server.xml文件修改如下位置内容 <Host name="localhost" appBase="webapps" unpackWA ...
- 转:mybatis3中@SelectProvider的使用技巧
mybatis3中@SelectProvider的使用技巧 mybatis的原身是ibatis,现在已经脱离了apache基金会,新官网是http://www.mybatis.org/. mybati ...
- 转:MVVM的基本入门简介
https://mp.weixin.qq.com/s?__biz=MzA3MjA4NjE3NQ==&mid=404502568&idx=1&sn=fe512f9820b99d3 ...
- 最简单简洁高效的Json数据解析
一.无图无真相 二.主要代码 1.导入jar包 拷贝fastjson.jar包到projectlibs包下 2.封装工具类JsonUtil.java package com.example.parse ...
- jQuery的AJax异步载入片段
主要用到load()方法以及getScript()方法,详细以一个样例说明: 在现有html文件里载入一个拟好的片段,以及在片段载入完毕之前阻止用户进一步操作的弹出框. 首先是现有html代码.无不论 ...
- Service和Activity交互之广播方式
一.使用场景如果要通知多个Activity,广播较为适合.但广播较为耗费性能. 二.Broadcast更新Activity中的UI 1.新建一个接口OnUpdateUI,用于回调更新UI public ...
- python 奇技淫巧
列表内部的字典的value进行排序 li = [{a:1,b:2,c:3,d:4},{e:5,f:6,g:7,h:8}] li = [{"day":2},{"day&qu ...