2014机试题:姓名的“夫妻相”

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

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

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define N 10
char *womanName[N]={"wang fei",
"zhang man yu",
"zhang zhi yi",
"li li",
"li xiao man",
"li yu cun",
"yang ni",
"xiao tong",
"li lei",
"zhang san"
};

void findMatch(char *woman[], char *man, char *output)
{
	int i;
	int count =0 ;
	int max = 0;
	int status = 0;

	for (i = 0 ; i < N; i++)
	{
		char *s = man;
		while(*s)
		{
			char *p = woman[i];
			while (*p)
			{
				if (*s == *p)
				{
					if (*s != ' ')
					{
						count++;
					}				
					break;
				}
				p++;			
			}
			s++;
		}
		if (count > max)
		{
			max = count;
			status = i;
		}
		count = 0;
	}
	strcpy(output, woman[status]);

}

int main()
{
	char manName[20];
	char match[20] = "";
	gets(manName);
	findMatch(womanName, manName, match);
	printf("%s\n", match);
	return 0;
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值