hdu6304 Balala Power!

本文介绍了一种解决特定26进制字符串处理问题的方法,通过高精度计算来确定每个字符的贡献,并进行合理的分配以达到最优解。使用了自定义的数据结构和算法来处理大数值计算中的比较问题。

http://acm.hdu.edu.cn/showproblem.php?pid=6034

基本的想法是统计出每个字母的贡献,然后贡献最小的就把更小的数字分给他

但这题关键在于贡献太大了,需要取模,又无法比较大小

所以我们想到因为只有26个字母,我们可以直接高精度算贡献,然后高精度比较大小,这题又是26进制的,那么我们高精度也搞26进制就行了,最后处理一遍进位

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;

const int maxl=1e5+10;
const int mod=1e9+7;

int n,cas;ll ans;
int alen[30],idx[30],dy[30];
int a[30][maxl];
struct node
{
	string s;
	int id;
}b[30];
bool vis[30],in[30];
char s[maxl];

inline void prework()
{
	for(int i=0;i<26;i++)
	{
		for(int j=0;j<=alen[i];j++)
			a[i][j]=0;
		alen[i]=0;vis[i]=false;in[i]=false;
	}
	int len,c,x;
	for(int i=1;i<=n;i++)
	{
		scanf("%s",s+1);
		len=strlen(s+1);
		vis[s[1]-'a']=true;
		for(int j=1;j<=len;j++)
		{
			c=s[j]-'a';
			a[c][len-j+1]++;
			alen[c]=max(alen[c],len-j+1);
		}
	}
	for(int i=0;i<26;i++)
	{
		b[i].id=i;
		for(int j=1;j<=alen[i];j++)
		{
			a[i][j+1]+=a[i][j]/26;
			a[i][j]%=26;
			if(a[i][j+1]>0)
				alen[i]=max(alen[i],j+1);
		}
	}
}

inline bool cmp(const int &x,const int &y)
{
	if(alen[x]!=alen[y])
		return alen[x]<alen[y];
	for(int i=alen[x];i>=1;i--)
	if(a[x][i]!=a[y][i])
		return a[x][i]<a[y][i];
	return x<y;
}

inline void mainwork()
{
	for(int i=0;i<26;i++)
		idx[i]=i;
	sort(idx,idx+26,cmp);
	for(int i=0;i<26;i++)
	if(!vis[idx[i]])
	{
		dy[idx[i]]=0,in[idx[i]]=true;
		break;
	}
	for(int i=1;i<26;i++)
		for(int j=0;j<26;j++)
		if(!in[idx[j]])
		{
			dy[idx[j]]=i,in[idx[j]]=true;
			break;
		}
	ll mi;ans=0;
	for(int i=0;i<26;i++)
	{
		mi=1;
		for(int j=1;j<=alen[i];j++)
		{
			ans=(ans+mi*dy[i]%mod*a[i][j]%mod)%mod;
			mi=mi*26%mod;
		}
	}
}

inline void print()
{
	++cas;
	printf("Case #%d: %lld\n",cas,ans);
}

int main()
{
	while(~scanf("%d",&n))
	{
		prework();
		mainwork();
		print();
	}
	return 0;
}

 

带开环升压转换器和逆变器的太阳能光伏系统 太阳能光伏系统驱动开环升压转换器和SPWM逆变器提供波形稳定、设计简单的交流电的模型 Simulink模型展示了一个完整的基于太阳能光伏的直流到交流电力转换系统,该系统由简单、透明、易于理解的模块构建而成。该系统从配置为提供真实直流输出电压的光伏阵列开始,然后由开环DC-DC升压转换器进行处理。升压转换器将光伏电压提高到适合为单相全桥逆变器供电的稳定直流链路电平。 逆变器使用正弦PWM(SPWM)开关来产生干净的交流输出波形,使该模型成为研究直流-交流转换基本操作的理想选择。该设计避免了闭环和MPPT的复杂性,使用户能够专注于光伏接口、升压转换和逆变器开关的核心概念。 此模型包含的主要功能: •太阳能光伏阵列在标准条件下产生~200V电压 •具有固定占空比操作的开环升压转换器 •直流链路电容器,用于平滑和稳定转换器输出 •单相全桥SPWM逆变器 •交流负载,用于观察实际输出行为 •显示光伏电压、升压输出、直流链路电压、逆变器交流波形和负载电流的组织良好的范围 •完全可编辑的结构,适合分析、实验和扩展 该模型旨在为太阳能直流-交流转换提供一个干净高效的仿真框架。布局简单明了,允许用户快速了解信号流,检查各个阶段,并根据需要修改参数。 系统架构有意保持模块化,因此可以轻松扩展,例如通过添加MPPT、动态负载行为、闭环升压控制或并网逆变器概念。该模型为进一步开发或整合到更大的可再生能源模拟中奠定了坚实的基础。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值