题意:给了一串15位或18位的身份证号码,求 在改变最少位数的情况下, 输出正确合法的身份证号

合法的身份证 是按照以下规则:

前6位以及“Order code”三位  一定合法

其中X是根据前17位的值计算出来的 按照如下公式  (a1就是最后一位,若为10就是X)

另外 题目还规定了“Date of Birth” 要在1900.1.1到2011.4.2之间

刚开始想这题的时候,觉得15位也就只需要 改变 年月日6位

            18位也就只需要 改变 年月日加X位9位而已

但是打起来发现并非这么简单。。。

单单是改变年月日就还需要考虑每月有多少天、需要考虑是否为闰年、需要考虑是否超过1900.1.1到2011.4.2的范围...

对于18位的,改变了前面 还有影响到X的

这样打下来相当之麻烦... 而且很容易错

因此不能采用这种方法

我们来换一种思路:

假设, 我们已经知道了  “在改变最少位数之后的身份证号码”  那么来计算与输入的有几位不一样,那是一件很方便的事

那么如何来得到 “在改变最少位数之后的身份证号码” 呢?

我们只需要遍历1900.1.1到2011.4.1之间的每一天 (这样想之后, 发现给了一个范围真好啊!!)

比较每一天与输入的需要改变几位,记录最小的 改变的位数 的那一天就好了

 string s;
int run[][]={{, , , , , , , , , , , },
{, , , , , , , , , , , }}; int w[]={, , , , , , , , , , , , , , , , , };
int a[], b[];
int ans[];
void copy(int y, int m, int d)
{
for(int i=; i<s.length(); i++)
b[i]=a[i];
if(s.length()==)
{
b[]=y%/, b[]=y%%;
b[]=m/, b[]=m%;
b[]=d/, b[]=d%;
}
else
{
b[]=y/, b[]=y/%, b[]=y%/, b[]=y%%;
b[]=m/, b[]=m%;
b[]=d/, b[]=d%;
}
}
int y, m, d;
bool cao()
{
if(y== && m== && d==)
return true;
int Y=y, M=m, D=d+;
if(run[((Y%== && Y%) || Y%==)][M-]+==D)
M++, D=;
if(M==)
Y++, M=;
copy(Y, M, D);
y=Y, m=M, d=D;
return false;
} int main()
{
int t;
scanf("%d", &t);
while(t--)
{
cin>>s;
for(int i=;i<s.length();i++)
a[i]=(s[i]=='X'? :s[i]-'');
y=, m=, d=;
int minn=;
copy(y, m, d);
while(true)
{
int num=;
if(s.length()==)
{
int sum=;
for(int i=; i<; i++)
sum+=b[i]*w[i];
b[]=(-sum%)%;
}
for(int i=; i<s.length(); i++)
if(b[i]!=a[i])
num++;
if(num<minn)
{
for(int i=; i<s.length(); i++)
ans[i]=b[i];
minn=num;
}
if(cao())
break;
}
for(int i=; i<s.length(); i++)
{
if(ans[i]!=)
printf("%d", ans[i]);
else
putchar('X');
}
puts("");
}
return ;
}

ZOJ 3485

[模拟]ZOJ3485 Identification Number的更多相关文章

  1. 银行卡BIN: Bank Identification Number

    What is a 'Bank Identification Number - BIN'A bank identification number (BIN) is the initial four t ...

  2. 模拟T1数字number

    那么第一题首先非常水的一道题…… 看一下题 数字(number) Time Limit:1000ms   Memory Limit:128MB 题目描述 LYK拥有n个数,这n个数分别是a1,a2,… ...

  3. 20180523模拟赛T4——Number

    [题目描述] 最近

  4. 210 - Concurrency Simulator(WF1991, deque, 模拟)

    题目有点长,理解题花了不少时间 粘下别人的翻译~ 你的任务是模拟n个程序(按输入顺序编号为1~n)的并行执行.每个程序包含不超过25条语句,格式一共有5种: var=constant(赋值): pri ...

  5. Cookies Client Identification

    HTTP The Definitive Guide Cookies are the best current way to identify users and allow persistent se ...

  6. Fat URLs Client Identification

    w在每个URL后面都附加一个用户特有的标识码. HTTP The Definitive Guide Some web sites keep track of user identity by gene ...

  7. RFID 基础/分类/编码/调制/传输

    不同频段的RFID产品会有不同的特性,本文详细介绍了无源的感应器在不同工作频率产品的特性以及主要的应用. 目前定义RFID产品的工作频率有低频.高频和甚高频的频率范围内的符合不同标准的不同的产品,而且 ...

  8. 左右v$datafile和v$tempfile中间file#

    v$datafile关于存储在文件中的数据视图的信息,v$tempfile查看存储在一个临时文件中的信息. 有两种观点file#现场,首先来看看官方文件的定义: V$DATAFILE This vie ...

  9. 深入javascript之对象

    前言 这是读书笔记第二篇,看完之后突然发现自己对js的内置的一些东西还是了解的不够全面,很多方法见都没见过,啥用都不知道,这是非常不可取的.码农好歹也得眼熟啊,晓都不晓得后面的学习还怎么进行下去... ...

随机推荐

  1. iOS开发——根据Url 获取图片尺寸

    转自:http://www.oschina.net/code/snippet_2248391_53038 // 根据图片url获取图片尺寸 +(CGSize)getImageSizeWithURL:( ...

  2. JSON的使用

    最近在项目中大量的使用了JSON, 发现JSON和XML的功能相近,都是一种数据传输格式.只是与XML相比JSON显得更加轻量级,使用也更加容易. JSON依赖的第三方jar包: commons-be ...

  3. AspectJ的简单使用

    aspectj是一款优秀的面向切面的编程框架,下面就简单介绍一下入门教程吧: 1.官网下载AspectJ的jar包,我这里下的是最新版本1.8.7的. 2.因为AspectJ.jar 是一个可执行的j ...

  4. IE下不支持option的onclick事件

    <select> <option onclick="test('www.hao123.com')"value="www.hao123.com" ...

  5. JSON参数解析工具类

    /// <summary> /// 解析JSON参数 /// </summary> public class JSONParser { JObject jObj = null; ...

  6. tomcat源码解读(1)–tomcat热部署实现原理

    tomcat的热部署实现原理:tomcat启动的时候会有启动一个线程每隔一段时间会去判断应用中加载的类是否发生变法(类总数的变化,类的修改),如果发生了变化就会把应用的启动的线程停止掉,清除引用,并且 ...

  7. Openvpn完美解决公司网络没有固定公网IP的问题

    方案背景: 公司办公网络使用长城宽带上网有一段时间了,有4个固定IP(2个电信,2个网通),链路不太稳定,经常有问题,因此考虑取消长城宽带,采用原来的adsl上网.但是有个问题,因为公司内网有几台服务 ...

  8. Linux进程间通信IPC学习笔记之消息队列(SVR4)

    Linux进程间通信IPC学习笔记之消息队列(SVR4)

  9. WPF后台更换背景图-Background

    Uri uri = new Uri("Images/BACK.gif", UriKind.Relative);BitmapImage bimg = new BitmapImage( ...

  10. Eclipse编辑器基本设置

    1.添加行号 在边缘处右键 2.改字体 字体的一般配置 3.去掉拼写错误检查 4.Java代码风格 代码格式化 Ctrl + Shift + F 之后点击右边的New按钮,新建一个风格. 点击OK 上 ...