您的位置:首页 > 其它

名字的漂亮度

2015-08-14 21:50 423 查看
描述
给出一个名字,该名字有26个字符串组成,定义这个字符串的“漂亮度”是其所有字母“漂亮度”的总和。
每个字母都有一个“漂亮度”,范围在1到26之间。没有任何两个字母拥有相同的“漂亮度”。字母忽略大小写。
给出多个名字,计算每个名字最大可能的“漂亮度”。

知识点字符串
运行时间限制0M
内存限制0
输入整数N,后续N个名字

N个字符串,每个表示一个名字

输出每个名称可能的最大漂亮程度

样例输入2 zhangsan lisi
样例输出192 101
<span style="font-size:18px;">#include<iostream>
#include<stdlib.h>
using namespace std;
int cmp(const void *a,const void *b) 
{ 
	return(*(char *)a-*(char *)b); 
}

void fun(char str[],int len)
{
	char temp[256];
	char last[256];
	memset(last,0,sizeof(last));
	memset(temp,0,sizeof(temp));
	int sum=0;
	int n=0;
	int num=26;
	for (int i=0;i<len;++i)
	{
		temp[str[i]]++;
	}
	for (int i=0;i<256;i++)
	{
		if (temp[i]!=0)
		{
			last[n++]=temp[i];
		}
	}
	qsort(last,n,sizeof(char),cmp);
	for (int i=n-1;i>=0;i--)
	{
		sum=sum+last[i]*num;
		num--;
	}

	cout<<sum<<endl;
}
int main()
{
	char str[1024];
	int n;
	cin>>n;
	for (int i=0;i<n;i++)
	{
		cin>>str;
		int len=strlen(str);
		fun(str,len);
	}
	
}</span>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: