网易互娱2017实习生招聘在线笔试第一场-电子数字
2016-03-24 21:07
323 查看
题目1 : 电子数字
时间限制:10000ms单点时限:1000ms
内存限制:256MB
电子数字在生活中很常见,而许多的电子数字是由LED数码管制作而成。数字LED数码管一般由7个发光二极管封装在一起,组成'8'字型,引线在内部连接完成。如下图所示,我们可以对每个发光管进行编码从1到7。而数字0到数字9可以由这七根发光管的亮暗来表示。
![](http://media.hihocoder.com//problem_images/20160314/14579394929229.jpg)
对LED数码管的二极管进行编码
![](http://media.hihocoder.com//problem_images/20160315/14580249187878.jpg)
用LED数码管表示数字0-9
假设我们现在有从左到右排列好的K个LED数码管,并且我们已知每个数码管当前有哪些编号的二极管是亮着的,另外剩余的二极管由于某些原因,我们并不清楚它们的亮暗情况。由于已经有部分二极管是确定亮着的,所以每个LED数码管能表示的数字范围会有所缩小,譬如假设1号二极管已经确定是亮着的状态,那么这个LED数码管就不能表示数字1和4。
我们想知道的是,给定一个数N,在这K个LED数码管的当前亮暗的状态下,所有可能表示的数中,比N小的数有多少个。
注意,前导0是必须的,假设有4个数码管的话,'0000'表示0,'0123'表示123,即每个数的表示方法唯一。
输入
每个输入数据包含多个测试点。
第一行为测试点的个数 S ≤ 100。之后是 S 个测试点的数据。测试点之间无空行。
每个测试点的第一行为 K(1 ≤ K ≤ 5)和N(0 ≤ N ≤ 109)。之后是K行,每行表示对应数码管已点亮的二极管的情况。每行至少包含一个数字,表示对应点亮的二极管的编号,即每个数码管至少有一根二极管是点亮的。二极管编号的范围保证在1到7之间,且每行无重复编号。
注意表示数码管点亮情况的每行数字之间以及行首行末之间可能存在冗余空格,每行的字符总长度不超过100。
输出
对于每个测试点,对应的结果输出一行,表示这K个数码管在当前状态下,所有可能表示的数中,比N小的数有多少个。
样例解释
第一个样例中,只有'020', '026', '028'符合要求。
第三个样例中,只有'000'符合要求。
样例输入
33 503 1 1 4 5 1 5 6 74 1001 2 3 4 56 7 1 1 7
样例输出
301思路:此题题目中变化形式有限只有10中情况,变化范围只能是从0到9,所以将0-9的二进制列出,以16进制存储,用于后续比较。比较方法:判断b的数码管形式是否包含a的数码管形式,其实就是比较两者的二进制位,a的二进制为1的位对应的b也要为1。最后用DFS进行递归,找出符合要求的进行统计输出。
代码:
#include <iostream> #include <stdio.h> using namespace std; int DGNM[10] = {0x77,0x12,0x5D,0x5B,0x3A,0x6B,0x6F,0x52,0x7F,0x7B};//每个LED数码管表示的0-9数字的每一位排列的十六进制表示。 int bin2dec(int * a)//将二进制转化为10进制。 { int t=1,sum=0; for(int i=7;i>-1;i--) { if(a[i]!=0) sum+=a[i]*t; t*=2; } return sum; } bool juge(int a,int b)//判断b的数码管排列是否包含a的形式 { for(int i=0;i<7;i++) { if((a%2)==1&&(b%2)==0)//a中为1的位,在b中也要为1 return false; a /=2; b /=2; } return true; } void DFS(int * dig,int cur,int sum,int N,int &flag,int l) { if(cur == -1)//终止条件:一种排列完成。 { if(sum < N) { flag++; } } else { for(int i=0;i<10;i++) { if(juge(dig[cur],DGNM[i])) { sum +=i*l; l *=10; cout << dig[cur] << " " << sum << endl; DFS(dig,cur-1,sum,N,flag,l); l /=10; sum -=i*l;//还原sum,否则会出现溢出情况。 } } } } void Turnover(int K,int N)//主函数:处理输入格式 { int temp[5][7] = {0}; int dig[5] = {0}; for(int i=0;i<K;i++) { char a; while((a=getchar())!='\n') { if(a!=' ') temp[i][a-'0'] = 1; } dig[i] = bin2dec(temp[i]); } int flag=0; DFS(dig,K-1,0,N,flag,1); cout << flag << endl; } int main() { Turnover(1,1); return 0; }
相关文章推荐
- 体验孤独
- TCP基础知识
- leetcode 144. Binary Tree Preorder Traversal
- LeetCode#101. Symmetric Tree
- Python实现的淘宝直通车数据抓取(3)
- POJ 3254 状压dp
- hdu1452 Happy 2004(规律+因子和+积性函数)
- SAS基础数据管理
- js遍历表格数据
- XML扩展性标记语言
- 我遇到的面试题
- PHP实用方法
- iOS资源汇总(开源项目、第三方库、技术博客等)
- 1.9-Redis持久化
- C#——判断一个数是奇偶性
- 修改button的text
- 面试题汇总
- Android手机无法使用google地图的问题的解决方案
- Objective-C——retain/copy/assign/atomic/nonatomic/strong/weak/readonly/readwrite详解
- 关于stm32 RTC配置相关说明