当前位置: 首页 > news >正文

P13270 【模板】最小表示法

题目背景

原模板题:P1368 工艺。

题目描述

若长度为 \(n\) 的字符串 \(s\) 中可以选择一个位置 \(i\),使得 \(\overline{s_i\cdots s_ns_1\cdots s_{i-1}}=t\),则称 \(s\)\(t\) 循环同构。字符串 \(s\)最小表示为与 \(s\) 循环同构的所有字符串中字典序最小的字符串。

给定一个长度为 \(n\) 的字符串 \(s\),请求出 \(s\) 的最小表示。

输入格式

第一行一个整数 \(n\)

第二行一个长度为 \(n\) 的字符串 \(s\)

输出格式

一行,一个字符串,为 \(s\) 的最小表示。

输入输出样例 #1

输入 #1

10
caacabcaab

输出 #1

aabcaacabc

说明/提示

对于全部数据,\(1\le n\le 10^7\),字符串 \(s\) 仅包含小写英文字母(ASCII \(97\sim 122\))。

设置以下三档部分分,用于测试不同解法:

  • 对于 \(20\%\) 的数据,\(n\le 10^3\)
  • 对于 \(50\%\) 的数据,\(n\le 10^5\)
  • 对于 \(100\%\) 的数据,无特殊限制。

思路

首先破环成链,将字符串复制一倍。
设置两个指针,\(i\)\(j\) 来表示对比的循环字符串的起点,\(k\)表示此时对比的位数是第\(k\)位。
那么会出现三种情况,若 \(s[i+k]==s[j+k]\) 那么 \(k++\) ,如果 \(s[i+k]>s[j+k]\) 那么i就移动到i+k+1的位置上,同理若 \(s[i+k]<s[j+k]\) ,那么j就移动到 \(j+k+1\) 的位置上。
为什么这么做是可以的呢,以 \(s[i+k]>s[j+k]\) 来说明,因为当i,j位置发生移动的时候,就说明有 \(s[i]到s[i+k-1]\) 的区间与 \(s[j]\)\(s[j+k]\) 的区间是一样的,下一位以 \(j\)开头更优,因此以i~i+k-1的区间作为开头的同时,j ~ j+k-1 的区间作为开头更优,因为到达 \(j+k\) 这一位的时候,这些区间内做开头显然都是j更优秀,所以可以直接跳过这段区间作为开头。

时间复杂度O(n)

题解

#include <bits/stdc++.h>
using namespace std;
const int N=1e5+10;
typedef long long ll;
int n;void solve()
{   cin>>n;string s;cin>>s;s = s+s;// cout<<s<<endl;int k = 0;int j=1,i=0;while(i<n&&j<n){   for(k=0;k<n&&s[i+k]==s[j+k];k++);if(s[i+k]>s[j+k])i = i+k+1;else j = j+k+1;if(i==j)j++;}int st = min(i,j);for(int i=st;i<st+n;i++)cout<<s[i];cout<<endl;}int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int t=1;// cin>>t;while(t--){solve();}return 0;
}
http://www.gsyq.cn/news/64453.html

相关文章:

  • 分布式Session会话实现优秀的方案
  • Revive Adserver存储型XSS漏洞技术分析
  • P2709 【模板】莫队 / 小B的询问
  • P1903 【模板】带修莫队 / [国家集训队] 数颜色 / 维护队列
  • Convolutional Neutral Network(CNN网络)
  • Product Hunt 每日热榜 | 2025-10-30 - 教程
  • 2025年Q4球墨铸铁管厂家TOP5排行榜:场景适配+成本优化,采购选型指南
  • `train_test_split` 是什么?
  • 解决LVGL与FATFS编码格式冲突及外挂字库方案
  • GraphRAG进阶:基于Neo4j与LlamaIndex的DRIFT搜索实现详解
  • noip板子
  • Linux_Socket_浅谈UDP - 教程
  • Jetlinks 物联网平台 开源版学习源码分析
  • Tita CRM一体化平台:破解销售管理五大痛点,实现业绩可持续增长
  • NOIP 算法合集
  • 使用cnpm(中国镜像源的npm客户端)来安装electron
  • 2025年11月中国电动叉车销售公司推荐榜单:主流品牌综合对比分析
  • 详细介绍:Qt样式深度解析
  • 替代模型简化复杂物理仿真任务
  • NOIP day -1 笔记
  • 2025-11-28 用前端react的架构来类比 NestJS 的各个部分(deepseek)
  • 【Microsoft Learn】Microsoft Azure 服务 - 教程
  • Spring AI 代码分析(十)--Spring Boot集成
  • WSL 迁移发行版位置
  • 详细介绍:Web安全深度实战:从漏洞挖掘到安全防护
  • 敬请人(自己)采/警示后人(自己)合辑
  • 使用RecyclerView.ItemDecoration自定义RecyclerView圆角滚动条
  • 技术分析:越南部分银行 App 不当使用 iOS 私有 API
  • Windows Docker 安装 RabbitMQ(包含客户端图形界面) - Higurashi
  • 《R语言医学数据分析实战》学习记录|第三章 数据框的操作