/*
HDU 6034 - Balala Power! [ 大数进位,贪心 ]
题意:
给一组字符串(小写英文字母),将上面的字符串考虑成26进制数,每个字母分配一个权值,问这组数字加起来的和最大是多少?
要求每个数字不能有前导0,即每个字符串首位字符不能赋0
分析:
对于每个字符,将每个字符串按位相加,得到这个字符的一个每位上的数量的数组
将其看成一个大数,满26进位,然后排序,从高到低赋值,注意考虑0
*/
#include <bits/stdc++.h>
using namespace std;
#define LL long long
const LL MOD = 1000000007;
LL mp[150005][26];
int n, m;
char s[100005];
bool notz[26];
int val[26], a[26];
void up()
{
for (int j = 0; j < 26; j++)
{
for (int i = 0; i < m; i++) {
mp[i+1][j] += mp[i][j] / 26;
mp[i][j] %= 26;
}
while (mp[m][j]) {
mp[m+1][j] += mp[m][j] / 26;
mp[m][j] %= 26;
m++;
}
}
}
bool cmp(int a, int b) {
for (int i = m-1; i >= 0; i--) {
if (mp[i][a] != mp[i][b]) return mp[i][a] > mp[i][b];
}
return 0;
}
void solve()
{
for (int i = 0; i < 26; i++) a[i] = i;
sort(a, a+26, cmp);
for (int i = 25; i >= 0; i--)
if (!notz[a[i]]) {
val[a[i]] = 0; break;
}
int tmp = 25;
for (int i = 0; i < 26; i++)
if (val[a[i]] == -1) val[a[i]] = tmp--;
}
int main()
{
int tt = 0;
while (~scanf("%d", &n))
{
memset(notz, 0, sizeof(notz));
memset(mp, 0, sizeof(mp));
memset(val, -1, sizeof(val));
m = 0;
for (int i = 1; i <= n; i++)
{
scanf("%s", s);
int len = strlen(s);
if (len != 1) notz[s[0]-'a'] = 1;
m = max(m, len);
for (int i = 0; i < len; i++) mp[len-i-1][s[i]-'a']++;
}
up();
solve();
LL ans = 0;
for (int i = m-1; i >= 0; i--)
{
ans = ans * 26 % MOD;
for (int j = 0; j < 26; j++)
{
ans = (ans + (LL)mp[i][j]*val[j] % MOD) % MOD;
}
}
printf("Case #%d: %lld\n", ++tt, ans % MOD);
}
}

  

HDU 6034 - Balala Power! | 2017 Multi-University Training Contest 1的更多相关文章

  1. 2017 Multi-University Training Contest - Team 1 1002&&HDU 6034 Balala Power!【字符串,贪心+排序】

    Balala Power! Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)T ...

  2. HDU 6034 Balala Power! —— Multi-University Training 1

    Talented Mr.Tang has nn strings consisting of only lower case characters. He wants to charge them wi ...

  3. hdu 6034 Balala Power!

    Balala Power! Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)T ...

  4. HDU 6034 Balala Power!(贪心+排序)

    Balala Power! Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) ...

  5. 2017ACM暑期多校联合训练 - Team 1 1002 HDU 6034 Balala Power! (字符串处理)

    题目链接 Problem Description Talented Mr.Tang has n strings consisting of only lower case characters. He ...

  6. HDU 6034 Balala Power!【排序/进制思维】

    Balala Power![排序/进制思维] Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java ...

  7. HDU 6034 Balala Power! (贪心+坑题)

    题意:给定一个 n 个字符串,然后问你怎么给 a-z赋值0-25,使得给定的字符串看成26进制得到的和最大,并且不能出现前导0. 析:一个很恶心的题目,细节有点多,首先是思路,给定个字符一个权值,然后 ...

  8. HDU 6170 - Two strings | 2017 ZJUT Multi-University Training 9

    /* HDU 6170 - Two strings [ DP ] | 2017 ZJUT Multi-University Training 9 题意: 定义*可以匹配任意长度,.可以匹配任意字符,问 ...

  9. hdu 6301 Distinct Values (2018 Multi-University Training Contest 1 1004)

    Distinct Values Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)T ...

随机推荐

  1. SQL SERVICES 搭建问题

    一.SQL SERVICES  设置IP 连接 SQL2008是没有外围配置的,为了能用IP地址或者local登陆,需要做下面的配置. 打开Microsoft SQL Server 2008 R2→配 ...

  2. JavaScript引用类型简单记录

    Object Array instanceof Function 引用类型 - Object {} 等价于 new Object() 我们经常使⽤用对象来承载可选参数,⽽而⽤用 命名的形式参数来传递必 ...

  3. 【重启C++】-- 序

    好久没看C++的东西了,该忘的也忘得差不多了,现在又要开始学,一点一滴的记录起来吧.

  4. 初遇PHP(一)

    因为想给自己弄一个微信公众号,顺便提升一下自己,所以有了以下内容,本次学习的最终目标是能用php制作套微信公众号,然后转成Java.为什么要这么麻烦呢,其一是买的资料书是php的,其二是顺水推舟刚好可 ...

  5. Python特色数据类型--列表

    #list[起始索引:终止索引(不包含):步长间隔] list1[5:8] #步长省略则默认为1 #修改元素列表 #列表是一种可变的数据类型,所以可以修改内容 list1 = [0,1,2,3,4] ...

  6. MySQL-复杂查询及条件-起别名-多表查询-04

    目录 基本查询语句及方法 测试数据创建 创建数据库与表 插入表记录数据 数据展示 常见结果排版 另一种结果排版 \G 简单查询语句的书写与执行顺序 查询语句书写 执行顺序 科普-- 起别名 写法 可以 ...

  7. CSS——font使用方法

    <style> p{ /*font-style: italic;/*设置字体为斜体*/ font-variant: small-caps; font-weight: bolder;/*设置 ...

  8. Where is __dso_handle defined?

    Where is __dso_handle defined? 来源  https://stackoverflow.com/questions/34308720/where-is-dso-handle- ...

  9. 03 Go语言特性

    一.基本注意事项 1.转义字符 \t 一个制表符,代表一次tab \n 换行符 \\ 转义代表 \ \" 转义代表 " \r 一个回车,从当前行的最前面开始输出,会覆盖以前的内容, ...

  10. java八个框架

    在本文中,我只是整理了以下主流框架: 1.阿帕切米纳 项目主页:http://mina.apache.org/ 它为开发高性能和高可用性网络应用提供了一个非常方便的框架,支持基于Java NIO技术的 ...