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

Posted jpphy0

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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;
}

以上是关于HDU 6034 Balala Power!(贪心 + 进制)的主要内容,如果未能解决你的问题,请参考以下文章

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

2017 Multi-University Training Contest - Team 1 1002&&HDU 6034 Balala Power!字符串,贪心+排序(示例代码(代

hdu 6034 Balala Power!

HDU 6034 Balala Power!排序/进制思维

Balala Power! HDU - 6034

HDU - 6034 Balala Power!