HDU 6034 Balala Power!(贪心 + 进制)

问题

HDU 6034 Balala Power! - https://acm.hdu.edu.cn/showproblem.php?pid=6034

分析

  • 通过进制方式比较大小
  • 任意一个字符串的首字符不能转换成 0 0 0
  • 存在多次进位的可能,例如:n个等长的字符串且首字相同,以下3处代码与此有关
const int N = 100010;
for(int j = N; j > N-mxlen-6; --j){
for(int i = N - mxlen - 6; i <= N; ++i)

代码

#include<bits/stdc++.h>
using namespace std;
const int N = 100010;
const int MXN = N + 15;
const int MD = 1e9 + 7;
int n, d[26][MXN], isf[26], mxlen, ans[26], f[MXN]={1};
char s[MXN];
int main(){
	int t = 0;
	for(int i = 1; i < MXN; ++i)
		f[i] = 1LL*f[i-1]*26%MD;
    while(scanf("%d", &n) == 1){
        memset(d, 0, sizeof d);
		memset(ans , 0, sizeof ans);
		memset(isf, 0, sizeof isf);
		mxlen = 0;
		while(n--){
			scanf("%s", s);
			isf[s[0]-'a'] = 1;
			int len = strlen(s);
			if(mxlen < len) mxlen = len;
			for(int i = len-1; i >= 0; --i) ++d[s[i]-'a'][N-len+1+i];
		}
        for(int i = 0; i < 26; ++i){
			for(int j = N; j > N-mxlen-6; --j){
				d[i][j-1] += d[i][j]/26, d[i][j] %= 26;
				ans[i] = (ans[i] + 1LL*d[i][j]*f[N-j])%MD;
			}
			s[i] = i;
		}
		sort(s, s+26, [](int x, int y){
			for(int i = N - mxlen - 6; i <= N; ++i) if(d[x][i] != d[y][i]) return d[x][i] < d[y][i];
			return false;
		});
		for(int i = 0; i < 26; ++i){
			if(isf[s[i]]) continue;
			for(int j = i; j > 0; --j) s[j-1] ^= s[j], s[j] ^= s[j-1], s[j-1] ^= s[j];
			break;
		}
		ans[s[0]] = 0;
		for(int i = 1; i < 26; ++i) ans[s[0]] = (ans[s[0]] + 1LL*ans[s[i]]*i)%MD;
        printf("Case #%d: %d\n", ++t, ans[s[0]]);
    }
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

jpphy0

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值