[模拟]ZOJ3485 Identification Number
题意:给了一串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的更多相关文章
- 银行卡BIN: Bank Identification Number
What is a 'Bank Identification Number - BIN'A bank identification number (BIN) is the initial four t ...
- 模拟T1数字number
那么第一题首先非常水的一道题…… 看一下题 数字(number) Time Limit:1000ms Memory Limit:128MB 题目描述 LYK拥有n个数,这n个数分别是a1,a2,… ...
- 20180523模拟赛T4——Number
[题目描述] 最近
- 210 - Concurrency Simulator(WF1991, deque, 模拟)
题目有点长,理解题花了不少时间 粘下别人的翻译~ 你的任务是模拟n个程序(按输入顺序编号为1~n)的并行执行.每个程序包含不超过25条语句,格式一共有5种: var=constant(赋值): pri ...
- Cookies Client Identification
HTTP The Definitive Guide Cookies are the best current way to identify users and allow persistent se ...
- Fat URLs Client Identification
w在每个URL后面都附加一个用户特有的标识码. HTTP The Definitive Guide Some web sites keep track of user identity by gene ...
- RFID 基础/分类/编码/调制/传输
不同频段的RFID产品会有不同的特性,本文详细介绍了无源的感应器在不同工作频率产品的特性以及主要的应用. 目前定义RFID产品的工作频率有低频.高频和甚高频的频率范围内的符合不同标准的不同的产品,而且 ...
- 左右v$datafile和v$tempfile中间file#
v$datafile关于存储在文件中的数据视图的信息,v$tempfile查看存储在一个临时文件中的信息. 有两种观点file#现场,首先来看看官方文件的定义: V$DATAFILE This vie ...
- 深入javascript之对象
前言 这是读书笔记第二篇,看完之后突然发现自己对js的内置的一些东西还是了解的不够全面,很多方法见都没见过,啥用都不知道,这是非常不可取的.码农好歹也得眼熟啊,晓都不晓得后面的学习还怎么进行下去... ...
随机推荐
- jquery学习全面总结
本文仅针对jquery的部分知识点做总结,更为全面的可以去官网看中文文档.可以更为详细的了解jquery及其特性. window.onload 和$(document).ready() 我 windo ...
- lex&yacc8--wehter use in C++
bintree.h:12:1: error: unknown type name ‘using’ using namespace std; ============== bintree.h:28:1: ...
- HTML5之拖放
- Draggable 标签 文件拖放 99年IE5开始,05后所有浏览器支持(除了opera) <li id=be draggable=true ondragstart="star ...
- ios 数字禁止变成电话号码
1.使用meta来限制页面不转换电话号码 <meta name="format-detection"content="telphone=no"/> ...
- javascript 面向对象技术
面向对象术语 对象 ECMA-262 把对象(object)定义为“属性的无序集合,每个属性存放一个原始值.对象或函数”.严格来说,这意味着对象是无特定顺序的值的数组. 尽管 ECMAScript 如 ...
- win7 vs2008 激活
参考:http://www.cnblogs.com/wgx0428/archive/2012/08/07/2627380.html win7需要管理员方式运行软件,才能看到输入框 软件:http:// ...
- 如何应用CLR线程池来管理多线程
class Program { static void Main(string[] args) { int intWorkerT ...
- [SQL SERVER系列]之嵌套子查询和相关子查询
子查询有两种类型,一种是只返回一个单值的子查询,这时它可以用在一个单值可以使用的地方,这时子查询可以看作是一个拥有返回值的函数:另外一种是返回一列值的子查询,这时子查询可以看作是一个在内存中临时存在的 ...
- willMoveToParentViewController 与 didMoveToParentViewController
在iOS 5.0以前,我们在一个UIViewController中这样组织相关的UIView 在以前,一个UIViewController的View可能有很多小的子view.这些子view很多时候被盖 ...
- 一道简单的IOS面试题-b
题目: (参考:陈曦 包子的iOS开发)我在code review的时候,发现了某个viewController中有这样一段代码,觉得很不妥当,请尝试找出代码中的任何问题,或者可以优化的部分. -(i ...