1. 手机号码合法性判断(20分)问题描述:我国大陆运营商的手机号码标准格式为:国家码+手机号码,例如:8613912345678。特点如下:1长度13位;2以86的国家码打头;3手机号码的每一位都是数字。请实现手机号码合法性判断的函数(注:考生无需关注手机号码的真实性,也就是说诸如86123123456789这样的手机号码,我们也认为是合法的),要求:1)如果手机号码合法,返回0;2)如果手机号码长度不合法,返回13)如果手机号码中包含非数字的字符,返回2;4)如果手机号码不是以86打头的,返回3;注除成功的情况外,以上其他合法性判断的优先级依次降低。也就是说,如果判断出长度不合法,直接返回1即可,不需要再做其他合法性判断。int verifyMsinsdn(char *inMsisdn)解:主要是思维的严谨性,一步一步的写int verifyMsinsdn(char *inMsisdn){
if(strlen(inMsisdn)!=13)
return 1;
for(int i=0;i<13;i++)
if(inMsisdn[i]<"0"||inMsisdn[i]>"9")
return 2;
if(inMsisdn[0]!="8"||inMsisdn[1]!="6")
return 3;
return 0;
}2. 将一个字符串的元音字母复制到另一个字符串,并排序(30分)问题描述:有一字符串,里面可能包含英文字母(大写、小写)、数字、特殊字符,现在需要实现一函数,将此字符串中的元音字母挑选出来,存入另一个字符串中,并对字符串中的字母进行从小到大的排序(小写的元音字母在前,大写的元音字母在后,依次有序)。说明:1:元音字母是a,e,i,o,u,A,E,I,O,U。2:筛选出来的元音字母,不需要剔重;3:最终输出的字符串,小写元音字母排在前面,大写元音字母排在后面,依次有序。void sortVowel (char* input, char* output);解,基本算法,此题可以利用STL里现成的算法#include<iostream>
#include<cstring>
#include<algorithm>
using namespace std;
void sortVowel (char* input, char* output)
{
string tmpLow,tmpUpper;
for(char *p=input; *p!=" ";++p)
{
if("a"==*p||"e"==*p||"i"==*p||"o"==*p||"u"==*p)
tmpLow+=*p;
else if("A"==*p||"E"==*p||"I"==*p||"O"==*p||"U"==*p)
tmpUpper+=*p;
}
sort(tmpLow.begin(),tmpLow.end());
sort(tmpUpper.begin(),tmpUpper.end());
tmpLow+=tmpUpper;
strcpy(output,tmpLow.c_str());
}3. 身份证号码合法性判断
问题描述:
我国公民的身份证号码特点如下:
1:长度为18位;
2:第1~17位只能为数字;
3:第18位可以是数字或者小写英文字母x。
4:身份证号码的第7~14位表示持有人生日的年、月、日信息。
例如:511002198808080111或51100219880808011x。
请实现身份证号码合法性判断的函数。除满足以上要求外,需要对持有人生日的年、月、日信息进行校验。年份大于等于1900年,小于等于2100年。需要考虑闰年、大小月的情况。所谓闰年,能被4整除且不能被100整除 或 能被400整除的年份,闰年的2月份为29天,非闰年的2月份为28天。其他情况的合法性校验,考生不用考虑。
函数返回值:
1) 如果身份证号合法,返回0;
2) 如果身份证号长度不合法,返回1;
3) 如果身份证号第1~17位含有非数字的字符,返回2;
4) 如果身份证号第18位既不是数字也不是英文小写字母x,返回3;
5) 如果身份证号的年信息非法,返回4;
6) 如果身份证号的月信息非法,返回5;
7) 如果身份证号的日信息非法,返回6(请注意闰年的情况);
除成功的情况外,以上其他合法性判断的优先级依次降低。也就是说,如果判断出长度不合法,直接返回1即可,不需要再做其他合法性判断。要求实现函数:int verifyIDCard(char* input)
输入char* input,表示输入的身份证号码字符串输出无
返回 判断的结果,类型为int
示例
1) 输入:”511002111222”,函数返回值:1;
2) 输入:”511002abc123456789”,函数返回值:2;
3) 输入:”51100219880808123a”,函数返回值:3;
4) 输入:”511002188808081234”,函数返回值:4;
5) 输入:”511002198813081234”,函数返回值:5;
6) 输入:”511002198808321234”,函数返回值:6;
7) 输入:”511002198808081234”,函数返回值:0;
解:不作解释,基本流程#include<iostream>
#include<memory>
using namespace std;
int verifyIDCard(char* input)
{
if(strlen(input)!=18)
return 1;
for(char *p=input; p!=input+17;++p)
if(!isdigit(*p))
return 2;
if(!isdigit(input[17])&&input[17]!="x")
return 3;
char year[5]="",mon[3]="",date[3]="";
memcpy(year,input+6,4);
memcpy(mon,input+10,2);
memcpy(date,input+12,2);
if(atoi(year)<1900||atoi(year)>2100)
return 4;
if(atoi(mon)<1||atoi(mon)>12)
return 5;
if(4==atoi(mon)||6==atoi(mon)||9==atoi(mon)){
if(atoi(date)<1||atoi(date)>30)
return 6;
}
else
{
if(atoi(mon)==2)
{
if(atoi(year)%400==0)
{
if(atoi(date)<1||atoi(date)>29)
return 6;
}
else
if(atoi(date)<1||atoi(date)>28)
return 6;
}
else
if(atoi(date)<1||atoi(date)>31)
return 6;
}
return 0;
}如何下载Tizen源码(图文教程)?2012年华为校园招聘机试(武汉)相关资讯 华为校园招聘
- 2012年华为校园招聘机试(南京) (06/09/2013 05:53:07)
- 2012年华为校园招聘机试(武汉) (06/07/2013 06:08:39)
| - 2012年华为校园招聘机试(成都) (06/07/2013 06:10:04)
|
本文评论 查看全部评论 (0)