P2237 [USACO14FEB]自动完成Auto-complete

  题意大概就是:给出n个字符串,有m个询问:每次给出字符串s,整数k,问在所有以s为前缀的字符串中,字典序第k大的,是那n个串中的第几个。

  我一开始做的时候忽略了一个问题:就是对于两个串a,b,你直接输出 a >  b 是有值的。也就是说,字符串是可以直接比较的,我们能O(1)两个串比较大小(因为就是asic码不是嘛)。

  显然,我们是要在以s为前缀的这个连续的整体里去判断。那么既然字符串的比较和整型变量一样,可以排序——这样就得到了连续的一段。

  这之后,我们只需要二分找第一个前缀 >= k 的,判断从这个开始第k个,和s是否相等就可以了。

  复杂度:O(1000 m log(n) ),没有问题。

  代码时间——

  

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<queue>
#include<string>
#include<vector>
using namespace std;
#define maxn 50000
struct node
{string s;int id;friend bool operator < (node a,node b){return a.s < b.s;}
} q[maxn];
int n,m;
int match(int p,string s)
{if(s.length()>q[p].s.length()) return -1;bool flag=0;for(int i=0;i<s.length();i++)if(q[p].s[i]!=s[i]) {flag=1;break;}if(flag) return -1;return q[p].id;
}
int find(string s)
{int L=1,R=n;int ans=0;while(L<=R){int mid=(L+R)>>1;if(q[mid].s>=s) {ans=mid;R=mid-1;}else L=mid+1;}return ans;
}
int solve(string s,int x)
{int p=find(s);if(p>n) return -1;p+=x-1;return match(p,s);
}
int main()
{scanf("%d%d",&n,&m);for(int i=1;i<=n;i++){cin>>q[i].s;q[i].id=i;}sort(q+1,q+n+1);for(int i=1;i<=m;i++){string s;int x;cin>>x>>s;cout<<solve(s,x)<<endl;}return 0;
}

 

  

转载于:https://www.cnblogs.com/popo-black-cat/p/10887011.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/462536.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HP-UX的终端TERM要设置成什么,才能输入中文呢?

再问一下,HP-UX的终端TERM要设置成什么,才能输入中文呢? 我试了,可以了,谢谢!非常感谢!/etc/profile中export LANGzh_CN.hp15CNstty cs8stty -istripstty -parenb怎么要设置这么多呀?我单独只设置stty -istrip也可以了,想请教你为什么要设置那么多??谢谢! 网址&#xff1a…

【SDOI 2011】Paint 染色

http://www.zybbs.org/JudgeOnline/problem.php?id2243 题目大意&#xff1a;给你一棵树&#xff0c;节点有颜色&#xff0c;要求可以查询某路径中连续颜色段的数目和修改某一段路径的颜色。 两次拉实之后查询和修改即可。 #include <iostream> #include <cstdio>…

部署Windows Server Update Services 4.0

在 Windows Server 2012 中&#xff0c;WSUS 是可安装以管理和分配更新的服务器角色。WSUS 服务器可以作为组织内其他 WSUS 服务器的更新源。充当更新源的 WSUS 服务器被称为上游服务器。在 WSUS 实现过程中&#xff0c;网络中必须至少有一台 WSUS 服务器连接到 Microsoft 更新…

克罗谈投资策略09

第七章 把注意力集中在长期趋势上&#xff08;2&#xff09; 我接到很多交易者寄来的信和打来的电话&#xff0c;谈论投机交易的各个层面。但是其中匹兹堡一位专业交易者1984年8月所写的一封信&#xff0c;跟上面所说的主题有特别的关联&#xff1a; 大家都说在目前的市场情况下…

dedecms织梦最新0day

拿webshell的方法如下&#xff1a; 网传的都是说要知道后台才能利用&#xff0c;但不用&#xff0c;只要 plus 目录存在&#xff0c;服务器能外连&#xff0c;就能拿shell. 前题条件&#xff0c;必须准备好自己的dede数据库&#xff0c;然后插入数据&#xff1a; insert into d…

JSP注释方法

<html><head><title>注释</title></head><body><!-- --> 这些是显示注释&#xff0c;不在页面中显示&#xff0c;但可以在客户端HTML源文件中看到&#xff0c;会被JSP引擎解释<!--例如&#xff1a;本文件加载日期为<%new …

《统计学习方法》(李航)读书笔记(转)

《统计学习方法》(李航)读书笔记(转) http://www.cnblogs.com/limitlessun/p/8611103.html#_label4阅读目录 知识点感知机k近邻法朴素贝叶斯决策树logistic回归和最大熵模型支持向量机提升方法EM算法隐马尔可夫模型(HMM)统计学习方法总结神经网络K-MeansBaggingApriori降维方法…

Windows 关闭进程例子

HANDLE handle CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,0);PROCESSENTRY32* info new PROCESSENTRY32;info->dwSize sizeof(PROCESSENTRY32);if(Process32First(handle,info)){if(GetLastError()ERROR_NO_MORE_FILES){TRACE("进程查找初始化失败&#xff01;&…

【转】Linux/ubuntu下apache+svn安装配置

Author:gaojinbo Time:2010-8-30 优点&#xff1a; 可以通过apache记录svn操作相关日志 环境&#xff1a; ubuntu 10.04.1 lts 64bit apache2.2 1.安装相关包 apt-get install apache2 libapache2-svn subversion cronolog 2.建立一个svn库 mkdir -p /www/svn/ svnadmin create…

SVN源码

SVN源码&#xff1a;http://code.google.com/p/tortoisesvn/source/browse/

html奇淫技巧 2 教你如何进行图文环绕布局 原创

在群里无意看到了盆友想要布局一个图文环绕的布局&#xff0c;问有没有什么办法实现&#xff0c;上网查了下&#xff0c;都感觉忽悠人的。 js 方面学的不怎么好&#xff0c;但是页面这块是不服输的。 于是就进行了研究&#xff0c;需求如下&#xff1a; 起先看到这张需求我是有…

Lync与Exchange 2013 UM集成:Lync Server配置

在完成了对Exchange的UM功能进行配置之后&#xff0c;我们要把UM的功能与Lync做集成的话还需要在Lync这边做一些配置。首先我们打开Lync前端服务器&#xff0c;然后打开核心组件安装目录下的Support文件夹&#xff0c;然后双击OcsUmUtil。打开之后我们单击加载数据&#xff0c;…

Windows下安装配置SubVersion的简明步骤

Windows下安装配置SubVersion的简明步骤 [使用的安装程序和文档说明] svn-1.4.0-setup.exe&#xff1a;Subversion服务端1.4.0安装程序&#xff1b; SubService.rar: SubServe服务Windows辅助工具; TortoiseSVN-1.4.0.7501-win32-svn-1.4.0.msi: 推荐使用的一个Windows资源管理…

LINUX-关机 (系统的关机、重启以及登出 )

shutdown -h now 关闭系统(1) init 0 关闭系统(2) telinit 0 关闭系统(3) shutdown -h hours:minutes & 按预定时间关闭系统 shutdown -c 取消按预定时间关闭系统 shutdown -r now 重启(1) reboot 重启(2) logout 注销 转载于:https://www.cnblogs.com/a-ant/p/10896448.ht…

在ubuntu中为程序添加图标快捷键

2019独角兽企业重金招聘Python工程师标准>>> 比如我在我的ubuntu上安装了javaEE eclipse&#xff0c;这个软件直接解压就可以用&#xff0c;这时在导航栏里没有对应图标&#xff0c;在左上角的软件中心中也没有图标&#xff0c;每次启动它得用命令来启动&#xff0c…

django--通过model拿到字段对象

import os os.environ.setdefault("DJANGO_SETTINGS_MODULE", "autoserver.settings")import django django.setup()from repository import modelsclsmodels.Disk #拿到所有的字段对象 for i in cls._meta.fields:print(i.name,i.verbose_name)#字段的名字…

FTP 和HTTP

http://zhidao.baidu.com/question/4917179.html FTP下载和HTTP下载有何不同&#xff1f; 互联网上有很多可以下载各种各样好用工具的站点。在这些站点下载文件时&#xff0c;您是否因需要选择“HTTP下载”和“FTP下载”而感到过不知所措呢&#xff1f;两者间究竟有什么区别呢&…

更改消息存储的位置

2019独角兽企业重金招聘Python工程师标准>>> 更改消息存储的位置 将消息存储位置更改为另一目录或文件系统。 开始之前 记录部署至要配置的集群的 IBM Lotus Connections 功能部件。 关于此任务 集群成员多于一个节点时&#xff0c;消息存储必须对集群中位于相同物…

【原创】StreamInsight查询系列(三)——基本查询操作之过滤

上篇博文介绍了如何在LINQPad中输出StreamInsight查询结果。这篇文章将主要介绍StreamInsight基础查询操作中的过滤部分。 测试数据准备 为了方便测试查询&#xff0c;我们首先准备一个静态的测试数据源&#xff1a;var weatherData new[] {new { Timestamp new DateTime(201…

(转)基于svnserve的服务器,权限文件authz配置的常见问题及解答

最近在我用Subversion论坛(http://www.iUseSVN.com/bbs)经常有人提到这样的问题&#xff1a;为什么我的客户端没有写权限&#xff1f;为什么我的权限没有起作用&#xff1f;总结他们的配置&#xff0c;发现都是用svnserve作为服务器&#xff0c;都在svnserve.conf中使用了authz…