[2018.07.31 T3] 第三题

字符串构造挑战
探讨如何从特定格式的输入字符串中寻找可重复子串,并在适当位置插入一个字符来构造原始字符串,涉及复杂度为O(n)的算法解决方案。

暂无链接

第三题

【问题描述】

有一个字符串S,你需要构造一个字符串T,使得T重复两次再在某个位置插入一个
字符后能得到S。

【输入格式】

一行一个字符串S。

【输出格式】

输出T,若无解,输出NOT POSSIBLE.若多解,输出NOT UNIQUE.

【输入样例1】

PUPILPQUPIL

【输出样例1】

PUPIL

【输入样例2】

PUPILPUPIL

【输出样例2】

NOT POSSIBLE

【输入样例3】

HAHAH

【输出样例3】

NOT UNIQUE

【样例说明3】

T可能是HA或AH。

【数据范围】

用n表示S的长度。

对于30%的数据,2<=n<=10;

对于60%的数据,2<=n<=2000;

对于100%的数据,2<=n<=2000000。

题解

史上最水题目名+不给部分分逼选手开$3$小时车系列。

直接$O(n)$枚举那个字母应该被删掉,用哈希花式过。

代码
#include<bits/stdc++.h>
#define ull unsigned long long
using namespace std;
const int N=2e6+5;
char ch[N];
ull base=19260817,mod=19491001,K[N],H[N];
int L;
void in(){scanf("%s",ch+1);}
void ac()
{
    L=strlen(ch+1);
    if((L&1^1)||L<=2)puts("NOT POSSIBLE"),exit(0);
    K[0]=1;for(int i=1;i<=L;++i)K[i]=K[i-1]*base;
    for(int i=1;i<=L;++i)H[i]=H[i-1]*base+ch[i];
    int M=1+L>>1,ans=0,res=1e9;bool f1=0,f2=0;
    ull hh,h1=H[M-1],h2=H[L]-H[M]*K[L-M];h1=h1+h1*K[M-1],h2=h2+h2*K[M-1];
    for(int i=1;i<=L;++i)
    {
        hh=H[L]-H[i]*K[L-i]+H[i-1]*K[L-i];
        if(i<M){if(hh==h2)res=i,f1=1;}else if(hh==h1){res=i,f2=1;}
        if(f1&&f2)break;
    }
    if(!f1&&!f2)puts("NOT POSSIBLE"),exit(0);
    if(f1&&f2&&h1!=h2)puts("NOT UNIQUE"),exit(0);
    if(res<M)for(int i=M+1;i<=L;++i)putchar(ch[i]);
    else for(int i=1;i<M;++i)putchar(ch[i]);
}
int main(){in();ac();}
SET @sql = NULL; SELECT JSON_ARRAYAGG( CONCAT(&#39;MAX(CASE WHEN td.person_name = &#39;&#39;&#39;, person_name, &#39;&#39;&#39; THEN td.work_time ELSE NULL END) AS &#39;&#39;&#39;, person_name, &#39;&#39;&#39;&#39;) ) INTO @sql FROM ( SELECT DISTINCT t2.person_name FROM task1 t1 INNER JOIN t_ps_person_work_time t2 ON t1.id = t2.task_id WHERE t2.work_day BETWEEN &#39;2025-06-26&#39; AND &#39;2025-07-25&#39; AND t2.status = 0 ) t; -- 更精确地移除JSON组格式 SET @sql = TRIM(BOTH &#39;[""]&#39; FROM @sql); SET @sql = REPLACE(@sql, &#39;","&#39;, &#39;", "&#39;); -- 可选,如果需要处理中间部分 -- 或者更简单的方式(如果只有两个元素): SET @sql = REPLACE(REPLACE(@sql, &#39;"&#39;, &#39;&#39;), &#39;,&#39;, &#39;, &#39;); SET @sql = REPLACE(@sql, &#39;[&#39;, &#39;&#39;); SET @sql = REPLACE(@sql, &#39;]&#39;, &#39;&#39;); WITH task_data AS ( -- 获取任务人员工时据 SELECT t3.task_num , t3.project_name , (SELECT dict_label FROM `js_sys_dict_data` WHERE dict_type = &#39;sys_project_type&#39; AND dict_value = t3.project_type) project_type, t1.duty_person person_name, ROUND(SUM(t2.work_time), 1) work_time, t2.work_day workDay FROM project t3 INNER JOIN task1 t1 ON t3.id = t1.project_id INNER JOIN ( SELECT person_name, task_id, work_time, DATE_FORMAT(work_day, &#39;%Y-%m&#39;) work_day FROM t_ps_person_work_time WHERE work_day BETWEEN &#39;2025-06-26&#39; AND &#39;2025-07-25&#39; AND `status` = 0 ORDER BY work_day ) t2 ON t1.id = t2.task_id WHERE t3.status = 0 AND t1.status = 0 GROUP BY t3.id,t1.person_code ORDER BY t3.task_num ) -- 动态透视表查询 SET @sql = CONCAT(&#39;SELECT td.task_num AS "任务书号", td.project_name AS "项目名称", td.project_type AS "项目类型", ROUND(SUM(td.work_time), 1) AS "项目工时", &#39;, @sql, &#39; FROM task_data td GROUP BY td.task_num ORDER BY td.task_num&#39;); -- 现在,@sql中存储了动态生成的SQL字符串 -- 使用预处理语句执行 PREPARE stmt FROM @sql; EXECUTE stmt; DEALLOCATE PREPARE stmt; 我这样修改,> 1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near &#39;SET @sql = CONCAT(&#39;SELECT td.task_num AS "任务书号", td.project_name A&#39; at line 29出现这个错误
最新发布
08-09
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ShadyPi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值