hdu-1172 猜数字
来源:互联网 发布:装小蜜 知乎 编辑:程序博客网 时间:2024/05/02 00:24
http://acm.hdu.edu.cn/showproblem.php?pid=1172
题意:根据一段对话来确定一个四位数。
思路:不要试图从已知条件去直接得出这个数,而是应该反过来看1000-9999内有多少数满足全部条件,不止一个或者0个就不确定,只有一个才算确定。
因为时间为10000ms,那么每次枚举1000-9999内的一个数即可。主要还是思路。
#include<cstdio>#include<cstring>int n,flag,m;struct node{ int x,y,z;}p[101];bool check(int s,node ss){ int f[5],ff[5],i,j,num=0; char vis[5]; memset(vis,0,sizeof(vis)); f[0]=s%10;f[1]=s/10%10;f[2]=s/100%10;f[3]=s/1000%10; ff[0]=ss.x%10;ff[1]=ss.x/10%10;ff[2]=ss.x/100%10;ff[3]=ss.x/1000%10; for(i=0;i<4;i++) //判断相同位置的个数是否相等 if(f[i]==ff[i]) { num++; } //printf("%d\n",num); if(num!=ss.z) return 0; //不想等 //printf("%d\n",num); num=0; for(i=0;i<4;i++) //判断相同个数是否相等 for(j=0;j<4;j++) if(!vis[j]&&f[i]==ff[j]) { vis[j]=1; num++; break; } //printf("%d\n",num); if(num!=ss.y) return 0; //不想等 return 1; }int main(){ //freopen("a.txt","r",stdin); int i,j,count; while(scanf("%d",&n)!=EOF) { if(n==0)break; count=0; for(i=0;i<n;i++) scanf("%d%d%d",&p[i].x,&p[i].y,&p[i].z); for(i=1000;i<=9999;i++) { flag=0; for(j=0;j<n;j++) { flag=check(i,p[j]); if(!flag)break; } if(flag) {m=i;count++;} //在这里保存 唯一值 } //printf("%d\n",count); if(count==1) printf("%d\n",m); else printf("Not sure\n"); } return 0;}
0 0
- hdu 1172 猜数字
- hdu 1172 猜数字
- hdu 1172 猜数字
- hdu(1172)猜数字
- hdu 1172 猜数字
- HDU-1172 猜数字
- hdu 1172 猜数字
- HDU 1172 猜数字
- hdu-1172 猜数字
- hdu 1172 猜数字
- Hdu 1172 猜数字
- hdu 1172 猜数字
- HDU 1172 猜数字
- HDU 1172 猜数字
- hdu 1172 猜数字
- HDU - 1172 猜数字
- HDU 1172 猜数字
- HDU:1172 猜数字
- android布局属性详解
- web.xml中load-on-startup的作用
- 25_C# 实现VMS客户端——控件_总结
- 柯西不等式证明(cauchy不等式)
- 环境: OpenMp入门系列1: OpenMP QT 编译配置
- hdu-1172 猜数字
- java 项目配置 伪静态
- Centos网站服务器使用DropBox定时备份方案
- 百度定位不成功后 android系统4.0.1不兼容 去掉option.setLocationNotify 就好了
- Windows下写Hadoop MapReduce程序
- 优惠券码生成
- mysql彻底卸载-增加远程权限-修改root密码
- iPads和iPones的Media Queries
- HDU - 3336 Count the string