POJ 2774 Long Long Message

本题地址:http://poj.org/problem?id=2774

Description

The little cat is majoring in physics in the capital of Byterland. A piece of sad news comes to him these days: his mother is getting ill. Being worried about spending so much on railway tickets (Byterland is such a big country, and he has to spend 16 shours on train to his hometown), he decided only to send SMS with his mother.

The little cat lives in an unrich family, so he frequently comes to the mobile service center, to check how much money he has spent on SMS. Yesterday, the computer of service center was broken, and printed two very long messages. The brilliant little cat soon found out:

  1. All characters in messages are lowercase Latin letters, without punctuations and spaces.
  2. All SMS has been appended to each other – (i+1)-th SMS comes directly after the i-th one – that is why those two messages are quite long.
  3. His own SMS has been appended together, but possibly a great many redundancy characters appear leftwards and rightwards due to the broken computer.
    E.g: if his SMS is “motheriloveyou”, either long message printed by that machine, would possibly be one of “hahamotheriloveyou”, “motheriloveyoureally”, “motheriloveyouornot”, “bbbmotheriloveyouaaa”, etc.
  4. For these broken issues, the little cat has printed his original text twice (so there appears two very long messages). Even though the original text remains the same in two printed messages, the redundancy characters on both sides would be possibly different.

You are given those two very long messages, and you have to output the length of the longest possible original text written by the little cat.

Background:

The SMS in Byterland mobile service are charging in dollars-per-byte. That is why the little cat is worrying about how long could the longest original text be.

Why ask you to write a program? There are four resions:
1. The little cat is so busy these days with physics lessons;
2. The little cat wants to keep what he said to his mother seceret;
3. POJ is such a great Online Judge;
4. The little cat wants to earn some money from POJ, and try to persuade his mother to see the doctor :(

Input

Two strings with lowercase letters on two of the input lines individually. Number of characters in each one will never exceed 100000.

Output

A single line with a single integer number – what is the maximum length of the original text written by the little cat.

Sample Input

yeshowmuchiloveyoumydearmotherreallyicannotbelieveit
yeaphowmuchiloveyoumydearmother

Sample Output

27

Source

POJ Monthly–2006.03.26,Zeyuan Zhu,”Dedicate to my great beloved mother.”

题解

很久没有写博客了。这题勒,后缀数组+高度数组的裸题:最长公共子串(这不很明显吗)。
第一次过后缀数组+高度数组,泪流涕下啊(HDU1403莫名WA)
这里的后缀数组是O(nlog²n)的版本
ps:子序列(subsequence)是不改变序列内元素顺序的前提下删除一些元素得到的新序列,而子串是原串中连续的一段

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <string>
using namespace std;
#define MAX_N 200010

int n,k;
int zrank[MAX_N+1];
int tmp[MAX_N+1];

bool cmp_sa(int i,int j) {
    if(zrank[i]!=zrank[j])
        return zrank[i]<zrank[j];
    else {
        int ri=i+k<=n?zrank[i+k]:-1;
        int rj=j+k<=n?zrank[j+k]:-1;
        return ri<rj;
    }
}

void construct_sa(string S,int *sa) {
    n=S.length();

    for(int i=0;i<=n;i++) {
        sa[i]=i;
        zrank[i]=i<n?S[i]:-1;
    }

    for(k=1;k<=n;k*=2) {
        sort(sa,sa+n+1,cmp_sa);

        tmp[sa[0]]=0;
        for(int i=1;i<=n;i++)
            tmp[sa[i]]=tmp[sa[i-1]]
            +(int)(cmp_sa(sa[i-1],sa[i]));
        for(int i=0;i<=n;i++) {
            zrank[i]=tmp[i];
        }
    }
}

void construct_lcp(string S,int *sa,int *lcp) {
    int n=S.length();
    for(int i=0;i<=n;i++)
        zrank[sa[i]]=i;

    int h=0;
    lcp[0]=0;
    for(int i=0;i<n;i++) {
        int j=sa[zrank[i]-1];

        if(h>0) h--;
        while(j+h<n&&i+h<n) {
            if(S[j+h]!=S[i+h])
                break;
            h++;
        }
        lcp[zrank[i]-1]=h;
    }
}

#define MAX_L 200010
string S,T;
int sa[MAX_L],lcp[MAX_L];

int main() {
    cin>>S>>T;
    int s1=S.length();
    S+='\0'+T;

    construct_sa(S,sa);
    construct_lcp(S,sa,lcp);

    int ans=0;
    for(int i=0;i<S.length();i++)
        if((sa[i]<s1)!=(sa[i+1]<s1))
            ans=max(ans,lcp[i]);
    printf("%d",ans);
}
基于51单片机,实现对直流电机的调速、测速以及正反转控制。项目包含完整的仿真文件、源程序、原理图和PCB设计文件,适合学习和实践51单片机在电机控制方面的应用。 功能特点 调速控制:通过按键调整PWM占空比,实现电机的速度调节。 测速功能:采用霍尔传感器非接触式测速,实时显示电机转速。 正反转控制:通过按键切换电机的正转和反转状态。 LCD显示:使用LCD1602液晶显示屏,显示当前的转速和PWM占空比。 硬件组成 主控制器:STC89C51/52单片机(与AT89S51/52、AT89C51/52通用)。 测速传感器:霍尔传感器,用于非接触式测速。 显示模块:LCD1602液晶显示屏,显示转速和占空比。 电机驱动:采用双H桥电路,控制电机的正反转和调速。 软件设计 编程语言:C语言。 开发环境:Keil uVision。 仿真工具:Proteus。 使用说明 液晶屏显示: 第一行显示电机转速(单位:转/分)。 第二行显示PWM占空比(0~100%)。 按键功能: 1键:加速键,短按占空比加1,长按连续加。 2键:减速键,短按占空比减1,长按连续减。 3键:反转切换键,按下后电机反转。 4键:正转切换键,按下后电机正转。 5键:开始暂停键,按一下开始,再按一下暂停。 注意事项 磁铁和霍尔元件的距离应保持在2mm左右,过近可能会在电机转动时碰到霍尔元件,过远则可能导致霍尔元件无法检测到磁铁。 资源文件 仿真文件:Proteus仿真文件,用于模拟电机控制系统的运行。 源程序:Keil uVision项目文件,包含完整的C语言源代码。 原理图:电路设计原理图,详细展示了各模块的连接方式。 PCB设计:PCB布局文件,可用于实际电路板的制作。
【四旋翼无人机】具备螺旋桨倾斜机构的全驱动四旋翼无人机:建模与控制研究(Matlab代码、Simulink仿真实现)内容概要:本文围绕具备螺旋桨倾斜机构的全驱动四旋翼无人机展开研究,重点进行了系统建模与控制策略的设计与仿真验证。通过引入螺旋桨倾斜机构,该无人机能够实现全向力矢量控制,从而具备更强的姿态调节能力和六自由度全驱动特性,克服传统四旋翼欠驱动限制。研究内容涵盖动力学建模、控制系统设计(如PID、MPC等)、Matlab/Simulink环境下的仿真验证,并可能涉及轨迹跟踪、抗干扰能力及稳定性分析,旨在提升无人机在复杂环境下的机动性与控制精度。; 适合人群:具备一定控制理论基础和Matlab/Simulink仿真能力的研究生、科研人员及从事无人机系统开发的工程师,尤其适合研究先进无人机控制算法的技术人员。; 使用场景及目标:①深入理解全驱动四旋翼无人机的动力学建模方法;②掌握基于Matlab/Simulink的无人机控制系统设计与仿真流程;③复现硕士论文级别的研究成果,为科研项目或学术论文提供技术支持与参考。; 阅读建议:建议结合提供的Matlab代码与Simulink模型进行实践操作,重点关注建模推导过程与控制器参数调优,同时可扩展研究不同控制算法的性能对比,以深化对全驱动系统控制机制的理解。
标题中的"EthernetIP-master.zip"压缩文档涉及工业自动化领域的以太网通信协议EtherNet/IP。该协议由罗克韦尔自动化公司基于TCP/IP技术架构开发,已广泛应用于ControlLogix系列控制设备。该压缩包内可能封装了协议实现代码、技术文档或测试工具等核心组件。 根据描述信息判断,该资源主要用于验证EtherNet/IP通信功能,可能包含测试用例、参数配置模板及故障诊断方案。标签系统通过多种拼写形式强化了协议主题标识,其中"swimo6q"字段需结合具体应用场景才能准确定义其技术含义。 从文件结构分析,该压缩包采用主分支命名规范,符合开源项目管理的基本特征。解压后预期可获取以下技术资料: 1. 项目说明文档:阐述开发目标、环境配置要求及授权条款 2. 核心算法源码:采用工业级编程语言实现的通信协议栈 3. 参数配置文件:预设网络地址、通信端口等连接参数 4. 自动化测试套件:包含协议一致性验证和性能基准测试 5. 技术参考手册:详细说明API接口规范与集成方法 6. 应用示范程序:展示设备数据交换的标准流程 7. 工程构建脚本:支持跨平台编译和部署流程 8. 法律声明文件:明确知识产权归属及使用限制 该测试平台可用于构建协议仿真环境,验证工业控制器与现场设备间的数据交互可靠性。在正式部署前开展此类测试,能够有效识别系统兼容性问题,提升工程实施质量。建议用户在解压文件后优先查阅许可协议,严格遵循技术文档的操作指引,同时需具备EtherNet/IP协议栈的基础知识以深入理解通信机制。 资源来源于网络分享,仅用于学习交流使用,请勿用于商业,如有侵权请联系我删除!
本项目旨在展示如何在STM32F4系列微控制器上通过SPI接口使用FatFS库来实现对SD卡的读写操作。STM32F4是一款高性能的ARM Cortex-M4内核MCU,广泛应用于嵌入式系统开发。该项目已成功调试通过,适用于需要在STM32F4平台进行文件存储的应用场景。 硬件配置 微控制器:STM32F4XX系列 SPI接口配置: Chip Select (CS):GPIOB Pin 11 Serial Clock (SCLK):GPIOB Pin 13 Master In Slave Out (MISO):GPIOB Pin 14 Master Out Slave In (MOSI):GPIOB Pin 15 请确保硬件连接正确,并且外部SD卡已被格式化为兼容FatFS的文件系统(如FAT16或FAT32)。 软件框架 编译环境:建议使用Keil uVision或STM32CubeIDE等常见STM32开发环境。 FatFS版本:此示例基于特定版本的FatFS库,一个轻量级的文件系统模块,专为嵌入式系统设计。 驱动实现:包括了SPI总线驱动和FatFS的适配层,实现了对SD卡的基本读写操作函数。 主要功能 初始化SPI接口:设置SPI模式、时钟速度等参数。 FatFS初始化:挂载SD卡到文件系统。 文件操作:包括创建、打开、读取、写入和关闭文件。 错误处理:提供了基本的错误检查和处理逻辑。 使用指南 导入项目:将代码导入到你的开发环境中。 配置环境:根据你所使用的IDE调整必要的编译选项和路径。 硬件连接:按照上述硬件配置连接好STM32F4与SD卡。 编译并烧录:确保一切就绪后,编译代码并通过编程器将其烧录到STM32F4中。 测试运行:连接串口监控工具,观察输出以验证读写操作是否成功。 注意事项 在尝试修改或集成到其他项目前,请理解核心代码的工作原理和依赖关系。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值