the beginning of_The king

the beginning of_The kingThe 2016 Asia Regional Contest, Tsukuba Quality of Check Digits Gym – 101158B

大家好,又见面了,我是你们的朋友全栈君。

题意:某城市公民每个人有一个五位数的id,前四位是basic id,最后一位是校验位,校验位是根据样例给出的表格得到的,设某公民的id为abcde,那么e=((((0$a)$b)$c)$d),每个公民都可能犯错误,例如将一位数字写错或者将相邻的两位调换,于是我们优秀的表格是应该可以判断出错的情况的,我们知道对于正确的id,(((((0$a)$b)$c)$d)$e)=0,但是等于0的不一定都是正确的,不等于0的一定是错误的,我们要求的是对于四位的basic id我们不能检验出来这个是否是正确的id的数量,也就是只要这个id出错的情况可能会被判正确,那么就是不可以的,ans就要加加

做法:直接模拟

坑点:例如1233 33调换之后与原来的值返回值也是一样的,这样即使一样也不能成为不能判断是否正确,因为33调换也是原来的值,这里特殊考虑就可以了。

代码如下:

#include<stdio.h>
#include<iostream>
#include<string.h>
#include<algorithm>

using namespace std;

int mp[10][10];
int num[10];
int ans;
//int vis[10];

int solve_1()
{
    int res = 0;
    for(int i=0; i<4; i++)
    {
        res = mp[res][num[i]];
    }
    return res;
}

int solve()
{
    int res = 0;
    for(int i=0; i<=4; i++)
    {
        res = mp[res][num[i]];
    }
    return res;
}

bool ok()
{
//    memset(vis , 0 , sizeof(vis));
    int ttmp;
    for(int i=0; i<5; i++)
    {
        ttmp = num[i];
        for(int j=0; j<10; j++)
        {
            if(j==ttmp) continue;
            num[i] = j;
            if(solve()==0)
                return false;
        }
        num[i] =ttmp;
    }
    if(num[0] != num[1])
    {
        swap(num[0], num[1]);
        if(solve()==0)
            return false;
        swap(num[0], num[1]);
    }
    if(num[1] != num[2])
    {
        swap(num[1], num[2]);
        if(solve()==0)
            return false;
        swap(num[1], num[2]);
    }
    if(num[2] != num[3])
    {
        swap(num[2], num[3]);
        if(solve()==0)
            return false;
        swap(num[2], num[3]);
    }
    if(num[3] != num[4])
    {
        swap(num[3], num[4]);
        if(solve()==0)
            return false;
    }
    return true;
}

int main()
{
    ans = 0;
    for(int i=0; i<10; i++)
        for(int j=0; j<10; j++)
            scanf("%d", &mp[i][j]);
    for(int i=0; i<10; i++)
    {
        for(int j=0; j<10; j++)
        {
            for(int p=0; p<10; p++)
            {
                for(int q=0; q<10; q++)
                {
                    num[0] = i;
                    num[1] = j;
                    num[2] = p;
                    num[3] = q;
                    num[4] = solve_1();
                    if( !ok() )
                    {
                        ans++;
//                        printf("%d %d %d %d %d \n", num[0], num[1], num[2], num[3], num[4]);
                    }
                }
            }
        }
    }
    printf("%d\n", ans);


    return 0;
}

 

转载于:https://www.cnblogs.com/Flower-Z/p/9787366.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/107254.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 设计模式(五)适配器模式Adapter(结构型)

    设计模式(五)适配器模式Adapter(结构型)设计模式(五)适配器模式Adapter(结构型)1.概述:接口的改变,是一个需要程序员们必须(虽然很不情愿)接受和处理的普遍问题。程序提供者们修改他们的代码;系统库被修正;各种程序语言以及相关库的发展和进化。例子1:iphone4,你即可以使用UBS接口连接电脑来充电,假如只有iphone没有电脑,怎么办呢?苹果提供了iphone电源适配器。………

    2022年7月25日
    11
  • 射频资料型号:RC522_RFID射频模块资料原厂代码PCB相关参考资料

    射频资料型号:RC522_RFID射频模块资料原厂代码PCB相关参考资料

    2022年7月14日
    15
  • 教你用Python自制一张好看的指数估值图!这招很好用!

    教你用Python自制一张好看的指数估值图!这招很好用!对于以定投指数的方式理财的朋友 最需要关注的指标便是各个指数的估值 在指数低估时买入 高估时卖出 那如何制作一张估值图来跟踪指数的估值情况呢 本文就从 0 到 1 介绍如何用 Matplotlib 画一张漂亮的指数估值图 准备数据首先 准备我们需要的数据 一般来说 经历了一轮牛熊周期的历史估值更具比较意义 所以 这里以上证指数 2013 年到目前为止的行情数据为例进行演示 同时 采用滚动市盈率为估值指标 数据来源为 tushare importpandas

    2025年6月1日
    3
  • python操作gitlab_git的使用教程

    python操作gitlab_git的使用教程文章目录一、安装git二、pycharm配置gitlab1、在pycharmsetting中设置git.exe的目录2、VCS—Checkoutfromversioncontrol—Git3、pycharm自动生成.ignore文件三、pycharm中gitlab基础操作1、分支2、pull3、push4、merge一、安装git下载地址:https://git-scm.com/downloads安装说明:https://git-scm.com/downloads二、pycharm配置

    2022年8月25日
    5
  • springboot连接mysql数据库配置文件「建议收藏」

    springboot连接mysql数据库配置文件「建议收藏」springboot连接mysql数据库配置文件:spring:datasource:username:rootpassword:rooturl:jdbc:mysql://localhost:3306/user_db?useUnicode=true&characterEncoding=utf-8&useSSL=true&serverTimezone=UTCdriver-class-name:com.mysql.jdbc.Driv

    2022年6月25日
    83
  • ubuntu 安装图形界面_ubuntu安装mpich详细教程

    ubuntu 安装图形界面_ubuntu安装mpich详细教程#cd/opt#sudowgethttps://raw.githubusercontent.com/rapid7/metasploit-omnibus/master/config/templates/metasploit-framework-wrappers/msfupdate.erb#sudomvmsfupdate.erbmsfinstall#sudochmod755…

    2025年9月24日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号