题解 | #字符串合并处理#

名字的漂亮度

http://www.nowcoder.com/practice/02cb8d3597cf416d9f6ae1b9ddc4fde3

给出多个名字,计算每个名字最大可能的“漂亮度”。
首先题目没有明确说明漂亮度是什么
因此先给出两个说明:
1.漂亮度为每个字符的权重,为了让总和最大,出现次数越多的字符,漂亮度就越大。
2.输出的漂亮度只和当前输入的字符串有关,输入字符串不同,可以定义不同的字符漂亮度。
也就是说输入为aaaab时a的漂亮度为最大26,b的漂亮度为25,次大,当第二个字符串为bbbba时,又可以将b的漂亮度设置为26,a的漂亮度设置为25,因此输入字符串不同,可以由不同的漂亮度。

思路:

  1. 接收字符串
  2. 求每一个字符出现的次数
  3. 按出现的次数排序
  4. 设置字符漂亮度
  5. 输出总体漂亮度

代码

#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
using namespace std;

int main()
{
    int num;
    while(cin >> num)
    {
        string get;
        while(num>0)
        {
            cin>>get;
            num--;
            vector<int> alp(26,0);
            for(int i=0;i<get.size();i++)//忽略输入大小写,将输入都转化为大写
                get[i]=toupper(get[i]);
            for(int i=0;i<get.size();i++)
            {
                ++alp[get[i]-'A'];
            }
            sort(alp.begin(),alp.end(),greater<int>());
            int sum=0;
            int index=0;
            int num=26;
            while(alp[index]!=0)
            {
                sum+=alp[index]*num;
                index++;
                num--;
            }
            cout<<sum<<endl;
        }
    }
    return 0;
}
全部评论

相关推荐

11-13 10:17
门头沟学院 Java
昨天面美团,jvm,juc问的好深啊,感觉小林coding不太够喔,牛油们有没有什么推荐的八股网站嘛🕒&nbsp;岗位/面试时间👥&nbsp;面试题目🤔&nbsp;面试感受
明天不下雨了:小林Coding:https://xiaolincoding.com/ 全栈哥:https://www.pdai.tech/ Guide哥:https://javaguide.cn/ 秀哥:https://interviewguide.cn/ 沉默王二:https://javabetter.cn/home.html 磊哥:https://www.javacn.site/interview/basic/ 小傅哥:https://bugstack.cn/ 源码哥:https://doocs.github.io/source-code-hunter/#/ 各大厂的公众号技术文章和一些经典的书籍
面试太紧张了怎么办?
点赞 评论 收藏
分享
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务