使用C#寫了一個(gè)可以推算火車票身份證號(hào)碼的小程序
1. 火車票上*號(hào)打的是月,日,理論上的有最大366種組合;
2. 校驗(yàn)碼是最后的一位,0-9及X,11個(gè)結(jié)果;
3. 那么,通過(guò)火車票上的身份證號(hào),可以得到33個(gè)左右真正的有效身份證號(hào);
4. 如果你能知道對(duì)方的星座(嗯,大家不是經(jīng)常曝自己是什么星座么),那么,再將這30多個(gè)結(jié)果映射到12個(gè)星座中,最終可能性只有2-3個(gè)。。。
5. 結(jié)論:曬車票,一定要打碼
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace Geyunfei.CheckID
{
class Program
{
static int[] a = new int[] { 7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2 };
static char[] b = new char[] { '1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2' };
static int index = 0;
static void Main(string[] args)
{
System.Console.WriteLine("輸入火車票上的身份證號(hào):");
String a = System.Console.ReadLine();
var year = int.Parse(a.Substring(6, 4));
var beginDate = new DateTime(year, 1, 1);
var chk = a.Substring(14);
int days = 365;
if (DateTime.IsLeapYear(year))
days++;
for(int i =0;i<days; i++)
{
var chkDate = beginDate.AddDays(i).ToString("MMdd");
var id = a.Substring(0, 10) + chkDate + chk;
CheckID(id);
}
}
private static void CheckID(string id)
{
int sum = 0;
for(int i = 0; i < 17; i++)
{
sum += int.Parse(id[i].ToString()) * a[i];
}
var chk = b[sum % 11];
if (chk == id[17])
{
index++;
Console.WriteLine(getAstro(int.Parse(id.Substring(10,2)),int.Parse(id.Substring(12,2)))+ index.ToString() +" "+id);
}
}
private static String getAstro(int month, int day)
{
String[] starArr = {"魔羯座","水瓶座", "雙魚座", "牡羊座",
"金牛座", "雙子座", "巨蟹座", "獅子座", "處女座", "天秤座", "天蝎座", "射手座" };
int[] DayArr = { 22, 20, 19, 21, 21, 21, 22, 23, 23, 23, 23, 22 }; // 兩個(gè)星座分割日
int index = month;
// 所查詢?nèi)掌谠诜指钊罩?,索?1,否則不變
if (day < DayArr[month - 1])
{
index = index - 1;
}
index = index % 12;
// 返回索引指向的星座string
return starArr[index];
}
}
}
相關(guān)文章
解析C#中委托的同步調(diào)用與異步調(diào)用(實(shí)例詳解)
本篇文章是對(duì)C#中委托的同步調(diào)用與異步調(diào)用進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下2013-05-05
使用C#程序驗(yàn)證系統(tǒng)登錄用戶與目錄權(quán)限
這篇文章主要介紹了使用C#程序驗(yàn)證系統(tǒng)登錄用戶與目錄權(quán)限,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12
C#實(shí)現(xiàn)Excel導(dǎo)入sqlite的方法
這篇文章主要介紹了C#實(shí)現(xiàn)Excel導(dǎo)入sqlite的方法,是C#程序設(shè)計(jì)中非常重要的一個(gè)實(shí)用技巧,需要的朋友可以參考下2014-09-09
c#檢測(cè)端口是否被占用的簡(jiǎn)單實(shí)例
這篇文章主要介紹了c#檢測(cè)端口是否被占用的簡(jiǎn)單實(shí)例,有需要的朋友可以參考一下2013-12-12

