[华为机试真题]69.姓名的夫妻相

原创 2015年07月07日 10:52:48

题目

在中国,形容夫妻恩爱的词汇中,大家用的比较多的就是“夫妻相”。所谓“夫妻相”,就是两个人看上去比较般配,长相、身材等某些方面有一定的相似度。
本题则另辟蹊径,从人的姓名维度,以字母重复个数来寻找最具“夫妻相”的人。
题目中预先给定一组女士的姓名拼音。输入男士的姓名拼音(拼音中间可以有空格,字母全部小写),依预先给定姓名拼音的先后遍历所有姓名,输出字母重复数最多的女士姓名。

规则1:如果字母重复数最多的女士有多位相同,则以最先匹配的女士做为最具“夫妻相”的人选。
规则2:人名中的相同字母,按重复一次处理。例如:li ling 与li lei 重复的字符个数为2,而不是4。
预置女士名单(先后循序必须保证):
"wang fei",
"zhang man yu",
"zhang zhi yi",
"li li",
"li xiao man",
"li yu cun",
"yang ni",
"xiao tong",
"li lei",
"zhang san"

运行时间限制:

无限制 

内存限制:

无限制 

输入:

输入一个男士姓名,字符串 

输出:

输出最具“夫妻相”的女士姓名

代码

/*---------------------------------------
*   日期:2015-07-07
*   作者:SJF0115
*   题目:姓名的夫妻相
*   来源:华为机试真题
-----------------------------------------*/
#include <iostream>
#include <string>
#include <vector>
#include <stack>
#include <algorithm>
using namespace std;

#define GirlSize 10

string girlName[GirlSize+1] = {"wang fei","zhang man yu","zhang zhi yi","li li","li xiao man","li yu cun","yang ni","xiao tong","li lei","zhang san"};

vector<vector<int> > hash(GirlSize,vector<int>(26,0));

// 预处理女士姓名
void Init(){
    for(int i = 0;i < GirlSize;++i){
        int count = girlName[i].size();
        for(int j = 0;j < count;++j){
            if(girlName[i][j] != ' '){
                ++hash[i][girlName[i][j] - 'a'];
            }//if
        }//for
    }//for
}

string MaxDupicate(string name){
    int size = name.size();
    // 去掉重复字符
    vector<int> boyHash(26,0);
    for(int k = 0;k < size;++k){
        if(name[k] != ' '){
            ++boyHash[name[k] - 'a'];
        }//if
    }//for
    int count = 0;
    int max = 0;
    // 记录重复数最多的女孩下标
    int index = 0;
    // 比较 获取重复数
    for(int i = 0;i < GirlSize;++i){
        count = 0;
        for(int j = 0;j < 26;++j){
            if(hash[i][j] > 0 && boyHash[j] > 0){
                ++count;
            }//if
        }//for
        // 更新最大值
        if(max < count){
            max = count;
            index = i;
        }//if
    }//for
    return girlName[index];
}

int main(){
    string name;
    //freopen("C:\\Users\\Administrator\\Desktop\\acm.txt","r",stdin);
    // 预处理
    Init();
    while(getline(cin,name)){
        cout<<MaxDupicate(name)<<endl;
    }//while
    return 0;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

华为机试—姓名的夫妻相

题目:夫妻相 在中国,形容夫妻恩爱的词汇中,大家用的比较多的就是“夫妻相”。所谓“夫妻相”,就是两个人看上去比较般配,长相、身材等某些方面有一定的相似度。 本题则另辟蹊径,从人的姓...

华为上机练习题--姓名夫妻相

题目: 在中国,形容夫妻恩爱的词汇中,大家用的比较多的就是“夫妻相”。所谓“夫妻相”,就是两个人看上去比较般配,长相、身材等某些方面有一定的相似度。本题则另辟蹊径,从人的姓名维度,以字母重复个数来寻...

2014华为机试真题(1)

1.及格线问题 10个学生考完期末考试评卷完成后,A老师需要划出及格线,要求如下: (1) 及格线是10的倍数; (2) 保证至少有60%的学生及格; (3) 如果所有的学生都高于60分,则及格线为6...

2014华为机试真题(2)

1.数字是否存在相同部分         求一个整型数字中有没有相同的部分,例如12386123这个整型数字中相同的部分是123,相同的部分至少应该是2位数,如果有相同部分返回1,如果没有则返回0。...

[华为机试真题]72.操作系统任务调度问题

题目操作系统任务调度问题。操作系统任务分为系统任务和用户任务两种。其中, 系统任务的优先级 < 50,用户任务的优先级 >= 50且 ...

[华为机试真题][2014]64.实现两个合法时间相加

题目描述: 给定两个合法的时间(格式固定:hh:mm:ss,时间合法,不用考虑其它情况),输入两个时间相加后的结果;注意,相加后的结果也必需是一个合法的时间; 附合法时间定义:小时在[00-23...

[华为机试真题]66.单词搜索

题目代码/*--------------------------------------- * 日期:2015-07-06 * 作者:SJF0115 * 题目:WordSearch * ...

[华为机试真题]73.公交站寻址

题目一个N*N二维矩阵代表城市布局,元素值只有’.’,’X’ , ‘B’ , ‘S’,X代表当前位置,B代表路障,S代表公交站,’.’代表可行的路径。 现给定路径长度Y,找到能够到达的公交站的个数,路...

[华为机试真题]68.简单四则运算

题目输入一个只包含个位数字的简单四则运算表达式字符串,计算该表达式的值 注: 3.1、表达式只含 +, -, *, / 四则运算符,不含括号 3.2、表达式数值只包含个位整数(0-9),且不会出现0作...

[华为机试真题]70.分苹果

题目M个相同苹果放到N个相同篮子里有多少种放法,允许有篮子不放。1
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:[华为机试真题]69.姓名的夫妻相
举报原因:
原因补充:

(最多只允许输入30个字)