2019.03.25 bzoj4567: [Scoi2016]背单词(trie+贪心)
传送门
题意:
给你n个字符串,不同的排列有不同的代价,代价按照如下方式计算(字符串s的位置为x):
1.排在s后面的字符串有s的后缀,则代价为n^2;
2.排在s前面的字符串有s的后缀,且没有排在s后面的s的后缀,则代价为x-y(y为最后一个与s不相等的后缀的位置);
3.s没有后缀,则代价为x。
求最小代价和。
思路:显然把所有字符串倒序建一个trietrietrie树出来。
然后在上面贪心每次走sizesizesize最小的子树最优。
代码:
#include<bits/stdc++.h>
#define ri register int
#define fi first
#define se second
using namespace std;
const int N=1e5+5,M=510005;
typedef long long ll;
typedef pair<int,int> pii;
char s[N];
int n;
ll ans=0;
namespace Trie{
    int son[M][26],siz[M],tot=1,rt=1,num[M],cnt=-1;
    bool ed[M];
    set<pii>e[M];
    inline void insert(char s[]){
        int p=rt;
        for(ri i=strlen(s)-1;~i;--i){
            if(!son[p][s[i]-'a'])son[p][s[i]-'a']=++tot;
            p=son[p][s[i]-'a'];
            ++siz[p];
        }
        ed[p]=1;
    }
    void build(int p=rt,int pre=rt){
        if(ed[p])e[pre].insert(pii(siz[p],p));
        for(ri i=0;i<26;++i)if(son[p][i])build(son[p][i],ed[p]?p:pre);
    }
    void dfs(int p=rt){
        num[p]=++cnt;
        for(set<pii>::iterator it=e[p].begin();it!=e[p].end();++it)dfs(it->se),ans+=num[it->se]-num[p];
    }
}
int main(){
    scanf("%d",&n);
    for(ri i=1;i<=n;++i)scanf("%s",s),Trie::insert(s);
    Trie::build();
    Trie::dfs();
    cout<<ans;
    return 0;
}
2019.03.25 bzoj4567: [Scoi2016]背单词(trie+贪心)的更多相关文章
- [BZOJ4567][SCOI2016]背单词(Trie+贪心)
		1.题意表述十分难以理解,简单说就是:有n个单词,确定一个背的顺序,使总代价最小. 2.因为第(1)种情况的代价是n*n,这个代价比任何一种不出现第(1)种情况的方案都要大,所以最后肯定不会出现“背某 ... 
- [bzoj4567][Scoi2016]背单词-Trie+贪心+模型转化
		Brief Description 给你N个互不相同的字符串,记\(S_i\)为第i个字符串,现在要求你指定N个串的出现顺序,我们用\(V_i\)表示第i个字符串是第几个出现的,则V为1到N的一个排列 ... 
- 【BZOJ4567】[Scoi2016]背单词 Trie树+贪心
		[BZOJ4567][Scoi2016]背单词 Description Lweb 面对如山的英语单词,陷入了深深的沉思,“我怎么样才能快点学完,然后去玩三国杀呢?”.这时候睿智 的凤老师从远处飘来,他 ... 
- BZOJ4567[Scoi2016]背单词
		4567: [Scoi2016]背单词 Time Limit: 10 Sec Memory Limit: 256 MB Submit: 304 Solved: 114 [Submit][Status] ... 
- [SCOI2016]背单词——trie树相关
		题目描述 Lweb 面对如山的英语单词,陷入了深深的沉思,”我怎么样才能快点学完,然后去玩三国杀呢?“.这时候睿智的凤老师从远处飘来,他送给了 Lweb 一本计划册和一大缸泡椒,他的计划册是长这样的: ... 
- BZOJ4567 SCOI2016背单词(trie+贪心)
		倒过来变成查询前缀.考虑怎么排序.第一条代价n*n就相当于inf,说明一个单词的所有前缀都要排在它前面.那么串的依赖关系就是trie的结构.二三条说明代价是Σidi-idfa,那么显然最后的编号应该是 ... 
- BZOJ4567 [Scoi2016]背单词   【trie树 + 贪心】
		题目链接 BZOJ4567 题解 题意真是鬼畜= = 意思就是说我们应先将一个串的所有后缀都插入之后再插入这个串,产生代价为其到上一个后缀的距离 我们翻转一下串,转化为前缀,就可以建\(trie\)树 ... 
- [bzoj4567][Scoi2016][背单词] (贪心+trie树)
		Description Lweb 面对如山的英语单词,陷入了深深的沉思,“我怎么样才能快点学完,然后去玩三国杀呢?”.这时候睿智 的凤老师从远处飘来,他送给了 Lweb 一本计划册和一大缸泡椒,他的计 ... 
- [SCOI2016] 背单词 (Trie 树,贪心)
		题目链接 大致题意 给你 \(n\) 个字符串, 要求你给出最小的代价. 对于每个字符串: 1.如果它的后缀在它之后,那么代价为 \(n^2\). 2.如果一个字符串没有后缀,那么代价为 \(x\), ... 
随机推荐
- 用word发布CSDN文章
			目前大部分的博客作者在用Word写博客这件事情上都会遇到以下3个痛点: 1.所有博客平台关闭了文档发布接口,用户无法使用Word,Windows Live Writer等工具来发布博客.使用Word写 ... 
- hibernate的开始
			1.1对象的持久化 对象持久化是指将内存中的对象保存到可永久保存的存储设备中(如磁盘)的一种技术.(hibernate是通过id来管理对象) 1.2怎样实现持久化 1 对象序列化 2 JDBC 3 O ... 
- C# 多线程传递参数或多个参数
			using System;using System.IO;using System.Text;using System.Threading; namespace ConsoleApp7{ class ... 
- Game Engine Architecture 1
			[Game Engine Architecture 1] 1.This book is really just the beginning of a fascinating and potential ... 
- Centos 7 docker 启动容器 iptables 报 No chain/target/match by that name
			我也遇到这个问题,原因时启动docker服务时没有启动iptables服务导致的(有些docker需要再iptables开放有些端口)解决方法1.启动iptables服务 CentOS 7 以下版本 ... 
- npm 离线安装依赖
			现实场景:一台自己的电脑可以连外网,一台开发机不能连网,开发机需要安装node_modules 依赖解决办法: npm 安装依赖分为两种,一是 -g 这种是安装在全局环境的,只有在电脑中 ... 
- 2018-2019-2 20175126谢文航 实验一《Java开发环境的熟悉》实验报告
			一.实验报告封面 课程:Java程序设计 班级:1751班 姓名:谢文航 学号:20175126 指导教师:娄嘉鹏 实验日期:2019年3月28日 实验时间:--- 实验序号:实验一 实验名称:Jav ... 
- 2018-2019-2 20165315 《网络对抗技术》Exp4 恶意代码分析
			2018-2019-2 20165315 <网络对抗技术>Exp4 恶意代码分析 一.实验要求 1.系统运行监控 使用如计划任务,每隔一分钟记录自己的电脑有哪些程序在联网,连接的外部IP是 ... 
- Centos7系统安装部署docker
			一.安装docker #创建docker相关的目录 mkdir -p /data/docker #安装docker运行必要工具 sudo yum install -y yum-utilsdevice- ... 
- vue全局API
			一.Vue.extend() 顾名思义 extend 继承,官方给出的解释是 (使用基础 Vue 构造器,创建一个“子类”.参数是一个包含组件选项的对象.) Vue构造器是指 vue是一个构 ... 
