• CoderForces 689A Mike and Cellphone (水题)


    题意:给定一个手机键盘数字九宫格,然后让你判断某种操作是不是唯一的,也就是说是不是可以通过平移也能实现。

    析:我的想法是那就平移一下,看看能实现,就四种平移,上,下,左,右,上是-3,要注意0变成8,如果有数字变成小于等于0了,那么就是不可以,同理,下是+3,8可以变成0,其他的也是这样,

    注意左右平移是147,和369,是不能平移,然后就AC了。再简化一下就是如果有123,就不能上移,如果有79就不能下移,如果有147就不能左移,如果有369就不能右移,如果有0就不能下左右移。

    代码如下:

    #include <iostream>
    #include <cstdio>
    
    using namespace std;
    const int maxn = 9 + 5;
    int a[maxn];
    int b[maxn];
    char s[maxn];
    
    int main(){
        int n;
        while(scanf("%d", &n) == 1 && n){
            scanf("%s", s);
            for(int i = 0; i < n; ++i)  a[i] = s[i] - '0';
            bool ok = false;
            for(int i = 0; i < n; ++i)//下
                if(a[i] && a[i] != 8)  b[i] = a[i] + 3;
                else if(a[i] == 8)  b[i] = 0;
                else b[i] = 10;
            int i;
            for(i = 0; i < n; ++i)  if(b[i] > 9)  break;
            if(i == n)  ok = true;
            for(i = 0; i < n; ++i)//上
                if(a[i])  b[i] = a[i] - 3;
                else b[i] = 8;
            for(i = 0; i < n; ++i)  if(b[i] <= 0)  break;
            if(i == n)  ok = true;
            for(i = 0; i < n; ++i)//右
                if(3 == a[i] || 6 == a[i] || 9 == a[i])  b[i] = 10;
                else if(a[i])  b[i] = a[i] + 1;
                else b[i] = 10;
            for(i = 0; i < n; ++i)  if(b[i] > 9)  break;
            if(i == n)  ok = true;
            for(i = 0; i < n; ++i)//左
                if(a[i] == 1 || a[i] == 4 || a[i] == 7)  b[i] = -10;
                else if(a[i])  b[i] = a[i] - 1;
                else b[i] = -10;
            for(i = 0; i < n; ++i)  if(b[i] <= 0)  break;
            if(i == n)  ok = true;
            if(!ok)  puts("YES");
            else  puts("NO");
        }
        return 0;
    }
    

     第二种:

    #include <iostream>
    #include <cstdio>
    
    using namespace std;
    const int maxn = 9 + 5;
    int a[maxn];
    int b[maxn];
    char s[maxn];
    
    int main(){
        int n;
        while(scanf("%d", &n) == 1 && n){
            scanf("%s", s);
            int l = 0, u = 0, r = 0, d = 0;
            for(int i = 0; i < n; ++i){
                if(s[i] == '0')  l = r = d = 1;
                if(s[i] == '1' || s[i] == '4' || s[i] == '7') l = 1;
                if(s[i] == '3' || s[i] == '6' || s[i] == '9') r = 1;
                if(s[i] == '1' || s[i] == '2' || s[i] == '3') u = 1;
                if(s[i] == '7' || s[i] == '9') d = 1;
            }
            if(u && d && l && r)  puts("YES");
            else  puts("NO");
        }
        return 0;
    }
    
  • 相关阅读:
    MySQL服务器变量:MySQL系列之八
    存储引擎:MySQL系列之七
    用户与授权:MySQL系列之六
    视图、存储函数、存储过程、触发器:MySQL系列之五
    SQL语法:MySQL系列之四
    关系型数据库基础概念:MySQL系列之开篇
    基础篇:MySQL系列之三
    多实例:MySQL系列之二
    安装篇:MySQL系列之一
    DNS
  • 原文地址:https://www.cnblogs.com/dwtfukgv/p/5649580.html
Copyright © 2020-2023  润新知