Description
_ _ _ _ _ _ _ _
| | | _| _||_||_ |_ ||_||_|
|_| ||_ _| | _||_| ||_| _|
Input
Output
Sample Input
2 _ _ _ _ _ | _ _|| _ || | _ |_ | | _ |_| _ _ _ _ _ _ ||_ _|| _| || | _ |_ | || |_|
Sample Output
Not Sure 0825
题意:一块电子表的液晶屏坏了,根据显示的字符判断前面输入的时间减去15分钟是否等于后面的时间,如果结果唯一输出前面的时间,否则就输出“Not Sure”。
思路:暴力;
具体:把0-9这10个数字转换成一维数组,与输入的作对比。
注意:测试数据“0000 2345”,“ _ _ _ _ _ _ _ ”
| ||_| || | | | ||_ |_
|_||_| ||_| |_| | _| _|。
ac代码:
1 #include<stdio.h> 2 #include<string.h> 3 #include<stdlib.h> 4 int s1[10][9]= {{0,1,0,1,0,1,1,1,1},{0,0,0,0,0,1,0,0,1},{0,1,0,0,1,1,1,1,0},{0,1,0,0,1,1,0,1,1},{0,0,0,1,1,1,0,0,1},{0,1,0,1,1,0,0,1,1},{0,1,0,1,1,0,1,1,1},{0,1,0,0,0,1,0,0,1},{0,1,0,1,1,1,1,1,1},{0,1,0,1,1,1,0,1,1}}; 5 int main() 6 { 7 int a,b,c,d,e,f,g,h,i,j,l,l1,n,vis[150],vis1[150],vis2[150],vis3[150],vis4[150],vis5[150],vis6[150],vis7[150]; 8 int x1[150],x2[150],x3[150],x4[150],x5[150],x6[150],x7[150],x8[10000],x9[15000],x[150],a1,a2,a3,a4,a5,a6,a7,a8,a9,a0,b1,b2,b3,b4,b5; 9 int y1[15000],y2[15000],y3[15000],y4[10500]; 10 scanf("%d",&n); 11 getchar(); 12 char s[150][100]; 13 while(n--) 14 { 15 a=0,b=0,c=0,d=0,e=0,f=0,g=0,h=0,a1=0,a2=0,a3=0,a4=0,a5=0,a6=0,a7=0,a8=0,a9=1,a0=0,b1=0,b2=0,b3=0,b4=0,b5=0,l=0,l1=0; 16 for(i=0;i<3;i++) 17 gets(s[i]); 18 for(i=0; i<3; i++) 19 { 20 for(j=0; j<3; j++) 21 { 22 if(s[i][j]==‘ ‘) 23 vis[a++]=0; 24 else 25 vis[a++]=1; 26 } 27 for(j=3; j<6; j++) 28 { 29 if(s[i][j]==‘ ‘) 30 vis1[b++]=0; 31 else 32 vis1[b++]=1; 33 } 34 for(j=6; j<9; j++) 35 { 36 if(s[i][j]==‘ ‘) 37 vis2[c++]=0; 38 else 39 vis2[c++]=1; 40 } 41 for(j=9; j<12; j++) 42 { 43 if(s[i][j]==‘ ‘) 44 vis3[d++]=0; 45 else 46 vis3[d++]=1; 47 } 48 for(j=13; j<16; j++) 49 { 50 if(s[i][j]==‘ ‘) 51 vis4[e++]=0; 52 else 53 vis4[e++]=1; 54 } 55 for(j=16; j<19; j++) 56 { 57 if(s[i][j]==‘ ‘) 58 vis5[f++]=0; 59 else 60 vis5[f++]=1; 61 } 62 for(j=19; j<22; j++) 63 { 64 if(s[i][j]==‘ ‘) 65 vis6[g++]=0; 66 else 67 vis6[g++]=1; 68 } 69 for(j=22; j<25; j++) 70 { 71 if(s[i][j]==‘ ‘) 72 vis7[h++]=0; 73 else 74 vis7[h++]=1; 75 } 76 } 77 for(i=0; i<10; i++) 78 { 79 a9=0; 80 for(j=0; j<10; j++) 81 { 82 a9++; 83 if(vis[j]>s1[i][j]) 84 { 85 a9=0; 86 break; 87 } 88 if(a9==9) 89 x[a0++]=i; 90 } 91 } 92 for(i=0; i<10; i++) 93 { 94 a9=0; 95 for(j=0; j<10; j++) 96 { 97 a9++; 98 if(vis1[j]>s1[i][j]) 99 { 100 a9=0; 101 break; 102 } 103 if(a9==9) 104 x1[a1++]=i; 105 } 106 } 107 for(i=0; i<10; i++) 108 { 109 a9=0; 110 for(j=0; j<10; j++) 111 { 112 a9++; 113 if(vis2[j]>s1[i][j]) 114 { 115 a9=0; 116 break; 117 } 118 if(a9==9) 119 x2[a2++]=i; 120 } 121 } 122 for(i=0; i<10; i++) 123 { 124 a9=0; 125 for(j=0; j<10; j++) 126 { 127 a9++; 128 if(vis3[j]>s1[i][j]) 129 { 130 a9=0; 131 break; 132 } 133 if(a9==9) 134 x3[a3++]=i; 135 } 136 } 137 for(i=0; i<10; i++) 138 { 139 a9=0; 140 for(j=0; j<10; j++) 141 { 142 a9++; 143 if(vis4[j]>s1[i][j]) 144 { 145 a9=0; 146 break; 147 } 148 if(a9==9) 149 x4[a4++]=i; 150 } 151 } 152 for(i=0; i<10; i++) 153 { 154 a9=0; 155 for(j=0; j<10; j++) 156 { 157 a9++; 158 if(vis5[j]>s1[i][j]) 159 { 160 a9=0; 161 break; 162 } 163 if(a9==9) 164 x5[a5++]=i; 165 } 166 } 167 for(i=0; i<10; i++) 168 { 169 a9=0; 170 for(j=0; j<10; j++) 171 { 172 a9++; 173 if(vis6[j]>s1[i][j]) 174 { 175 a9=0; 176 break; 177 } 178 if(a9==9) 179 x6[a6++]=i; 180 } 181 } 182 for(i=0; i<10; i++) 183 { 184 a9=0; 185 for(j=0; j<10; j++) 186 { 187 a9++; 188 if(vis7[j]>s1[i][j]) 189 { 190 a9=0; 191 break; 192 } 193 if(a9==9) 194 x7[a7++]=i; 195 } 196 } 197 for(i=0; i<a0; i++) 198 { 199 for(j=0; j<a1; j++) 200 if((x[i]*1000+x1[j]*100)<2400) 201 { 202 x8[a8++]=x[i]*1000+x1[j]*100; 203 } 204 } 205 for(i=0; i<a4; i++) 206 { 207 for(j=0; j<a5; j++) 208 if((x4[i]*1000+x5[j]*100)<2400) 209 { 210 x9[b1++]=x4[i]*1000+x5[j]*100; 211 } 212 } 213 for(i=0; i<a2; i++) 214 { 215 for(j=0; j<a3; j++) 216 if((x2[i]*10+x3[j])<60) 217 { 218 y1[b2++]=x2[i]*10+x3[j]; 219 } 220 } 221 for(i=0; i<a6; i++) 222 { 223 for(j=0; j<a7; j++) 224 if((x6[i]*10+x7[j])<60) 225 { 226 y2[b3++]=x6[i]*10+x7[j]; 227 } 228 } 229 for(i=0; i<a8; i++) 230 for(j=0; j<b2; j++) 231 { 232 y3[b4++]=x8[i]+y1[j]; 233 } 234 for(i=0; i<b1; i++) 235 for(j=0; j<b3; j++) 236 { 237 y4[b5++]=x9[i]+y2[j]; 238 } 239 int num=0,sum=0; 240 for(i=0; i<b4; i++) 241 { 242 for(j=0; j<b5; j++) 243 { 244 sum=y3[i]; 245 num=y3[i]%100; 246 if(sum<15) 247 { 248 sum+=2400; 249 } 250 if(num<15) 251 { 252 sum=sum-40; 253 } 254 num=sum-15; 255 if(num==y4[j]) 256 { 257 l++; 258 l1=y3[i]; 259 } 260 } 261 } 262 if(l==1) 263 printf("%04d\n",l1); 264 else 265 printf("Not Sure\n"); 266 } 267 }
poj 1676 What time is it?,布布扣,bubuko.com
原文:http://www.cnblogs.com/Xacm/p/3825831.html