/*
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. 小记--------SparkContext初始化原理机制图解

  2. 01背包方案数(变种题)Stone game--The Preliminary Contest for ICPC Asia Shanghai 2019

    题意:https://nanti.jisuanke.com/t/41420 给你n个石子的重量,要求满足(Sum<=2*sum<=Sum+min)的方案数,min是你手里的最小值. 思路: ...

  3. LeetCode 141 ——环形链表(JAVA)

    给定一个链表,判断链表中是否有环. 为了表示给定链表中的环,我们使用整数 pos 来表示链表尾连接到链表中的位置(索引从 0 开始). 如果 pos 是 -1,则在该链表中没有环. 示例 1: 输入: ...

  4. ZOOKEEPER进阶

    集群个数: 2n+1,因为集群当宕机大于等于二分之一的机子时,集群选举会失败.故 2n+1台机器和3n台机器可靠性相同 Leader的作用: 为了实现各个节点数据的一致性,需要一个负责协调数据同步的操 ...

  5. C# 操作地址 从内存中读取写入数据(初级)

    本示例以植物大战僵尸为例, 实现功能为 每1秒让阳光刷新为 9999.本示例使用的游戏版本为 [植物大战僵尸2010年度版], 使用的辅助查看内存地址的工具是  CE. 由于每次启动游戏, 游戏中阳光 ...

  6. .NET监视程序运行时间

    使用Stopwatch类(命名空间:System.Diagnostics;) 示例: using System; using System.Collections.Generic; using Sys ...

  7. httpclient 上传附件实例

    httpclient 单附件上传实例  (扩展多附件上传实例,点我) /** * 上传附件 * @param host * @param uri * @param filePath 文件路径 * @p ...

  8. yii2-cache组件第三个参数Dependency $dependency的作用浅析

    用法如下: $cache->set($key, $result, Configs::instance()->cacheDuration, new TagDependency([ 'tags ...

  9. Nginx自动加载配置文件方案

    nginx自动加载配置文件方案一.nginx+consul+consul-template实现过程:consul作为服务发现软件,consul-template作为nginx配置文件的模板,consu ...

  10. Windows环境中编译opencv3.0同时加入OPENCV_contrib库及解决遇到相关问题[contrib 必须要3.1以上的opencv才支持了]

    更新:现在contrib库必须要opencv3.1以上才能支持编译通过了. 方法和步骤还是和本篇文章一样. ############################################## ...