第六十六练 最长回文子串 - Manacher算法

简介: 第六十六练 最长回文子串 - Manacher算法

第六十六练 最长回文子串 - Manacher算法

要求:1、输入一个字符串 2、使用Manacher算法实现,找到并输出给定字符串的最长回文子串 3、输出最长回文子串及其长度

第六十五练答案

以下是一个简单的C语言实现,用于实现Rabin-Karp算法,判断第一个字符串是否包含第二个字符串:

#include <stdio.h>
#include <string.h>
#include <math.h>

#define PRIME 101 // A prime number used in the hash function

int rabinKarpSearch(const char *text, const char *pattern) {
    int n = strlen(text);
    int m = strlen(pattern);
    int i, j;
    int hash_pattern = 0; // Hash value for the pattern
    int hash_text = 0;    // Hash value for the current text window
    int h = 1;

    // Calculate h, which is the hash value for the next window of text
    for (i = 0; i < m - 1; i++) {
        h = (h * 256) % PRIME;
    }

    // Calculate the initial hash values for the pattern and the first window of text
    for (i = 0; i < m; i++) {
        hash_pattern = (256 * hash_pattern + pattern[i]) % PRIME;
        hash_text = (256 * hash_text + text[i]) % PRIME;
    }

    // Slide the pattern over the text one position at a time and check for a match
    for (i = 0; i <= n - m; i++) {
        if (hash_pattern == hash_text) {
            // If the hash values match, perform a character-by-character comparison
            for (j = 0; j < m; j++) {
                if (text[i + j] != pattern[j]) {
                    break;
                }
            }
            if (j == m) {
                return i; // Match found, return the starting index
            }
        }

        // Calculate the hash value for the next window of text
        if (i < n - m) {
            hash_text = (256 * (hash_text - text[i] * h) + text[i + m]) % PRIME;
            if (hash_text < 0) {
                hash_text += PRIME; // Ensure the hash value is non-negative
            }
        }
    }

    return -1; // No match found
}

int main() {
    char text[100], pattern[100];

    printf("Enter the text string: ");
    scanf("%s", text);

    printf("Enter the pattern string: ");
    scanf("%s", pattern);

    int result = rabinKarpSearch(text, pattern);

    if (result != -1) {
        printf("Match found at index %d\n", result);
    } else {
        printf("No match found\n");
    }

    return 0;
}

此程序使用Rabin-Karp算法实现字符串匹配,输出匹配结果。

答案和解析会在次日公布

注意事项

编写代码的时候,需要注意以下几点问题:

  • 头文件的引用需要放在代码的最顶部
  • 每个C语言程序中必须包含一个 main函数
  • void main(){}
  • int main(){return 0;}
  • C语言中每一行的结尾处必须要使用分号结尾
  • C语言中的引号需要使用双引号,双引号都是以一对一对的情况出现的
  • 在scanf键盘输入代码中,要使用 & 加变量名来读取一个键盘输入
  • 赋值语句是将右边的值赋给左边的变量,顺序不能反了
  • 需要注意代码的缩进格式,缩进为4个空格或者一个tab键为一组,但是要保证整篇代码里面风格一致,要么都是4个空格缩进,要么都是使用一个tab进行缩进
  • 需要养成随手保存的习惯,保存的快捷键一般是 ctrl + s
  • 注意大括号的使用,大括号是代码块,代表了一个块的代码是放在一起的
  • 注意整数型和实数型的转换,如果将实数赋值给一个整形变量,那么实数的小数部分将会被舍去;
  • 注意除法中,如果除数和被除数都是整数,那么结果也会是一个整数,小数部分会自动舍弃
  • 成对出现的标点符号
  • 单引号,双引号,小括号,中括号,大括号等,一般不单独出现
  • 如果代码有问题,然后附近又刚好有这些成对符号,请着重关注
  • 定义变量时,该打的逗号应该打上,不能写掉了
  • 编写++符号时,不要误写成了ff
  • 一个程序里面只能有一个main函数,除了main函数的其他函数都不能叫这个名字
  • 在调用函数时,入参都是使用的逗号隔开,一定不要使用分号隔开
  • 换行符是\n,不能错误写成/n
  • 输入输出格式化
  • %.2f是保留两位小数
  • %d对应整数
  • %c对应字符
  • %f对应实数
  • 不要写错或者写漏了
  • if条件语句当前行不能加分号,不然这个语句就没有意义了
  • while语句和if语句一样,当行不能加分号
  • 不建议使用goto语句,因为那样会造成程序结构的混乱,导致不可读

更多

「欢迎来到C语言每日一练服务!」

在现代技术的飞速发展中,编程已经成为一项不可或缺的技能。C语言作为一门经典的编程语言,奠定了计算机科学的基石,为学习其他编程语言打下了坚实的基础。为了帮助大家更好地掌握C语言,我们特别推出了每日一练服务,旨在提供系统性、全面性的学习支持。

「我们的服务特点包括:」

  1. 「日常练习题目:」 每天我们会提供一道C语言练习题目,涵盖基础知识、算法、数据结构等多个领域。这些题目既有难度,又具有实际应用价值,帮助你锻炼编程技能。
  2. 「详细解析:」 我们不仅提供每道题的标准答案,还会提供详细的解析和优秀代码示例。通过对解题思路的深入剖析,你能够更好地理解和掌握各种编程技巧。
  3. 「互动学习社区:」 通过微信文章评论区建立了一个互动学习社区,供学员们交流讨论。你可以在这里提问问题、分享经验,与其他学员一起成长。
  4. 「个性化学习建议:」 根据你的学习表现,我们会为你推荐相应难度的练习题,确保你的学习过程既具挑战性,又不至于过于困难,保持学习的动力和兴趣。

「参与每日一练的好处:」

  • 「持续学习提升技能:」 每日坚持练习,你的编程技能将会得到持续提升,不断进步。
  • 「增强自信心:」 通过解决各种类型的问题,你将建立起对自己技能的信心,更加轻松应对编程挑战。
  • 「拓宽思路:」 每道题都是一个小挑战,通过解决这些问题,你将培养出灵活的思维,更好地应对实际编程工作中的挑战。
  • 「为未来发展奠定基础:」 无论你是初学者还是有一定经验的程序员,C语言每日一练都将为你未来的编程发展奠定坚实的基础。

加入我们的C语言每日一练服务,一起挑战编程难题,不断提升自己,走向编程高手的道路!


目录
相关文章
|
2月前
|
算法
【算法沉淀】最长回文子串
【算法沉淀】最长回文子串
|
2月前
|
算法
LeetCode算法题---最长回文子串、N 字形变换(四)
LeetCode算法题---最长回文子串、N 字形变换(四)
29 0
|
2月前
|
算法 C#
Leetcode算法系列| 5. 最长回文子串
Leetcode算法系列| 5. 最长回文子串
|
2月前
|
存储 算法 程序员
【算法训练-字符串 一】【子串问题】最长无重复子串、最长回文子串、最长公共前缀
【算法训练-字符串 一】【子串问题】最长无重复子串、最长回文子串、最长公共前缀
48 0
|
12月前
|
机器学习/深度学习 存储 算法
【力扣算法08】之 5. 最长回文子串 python
【力扣算法08】之 5. 最长回文子串 python
111 0
|
1天前
|
算法 安全 数据库
基于结点电压法的配电网状态估计算法matlab仿真
**摘要** 该程序实现了基于结点电压法的配电网状态估计算法,旨在提升数据的准确性和可靠性。在MATLAB2022a中运行,显示了状态估计过程中的电压和相位估计值,以及误差随迭代变化的图表。算法通过迭代计算雅可比矩阵,结合基尔霍夫定律解决线性方程组,估算网络节点电压。状态估计过程中应用了高斯-牛顿或莱文贝格-马夸尔特法,处理量测数据并考虑约束条件,以提高估计精度。程序结果以图形形式展示电压幅值和角度估计的比较,以及估计误差的演变,体现了算法在处理配电网状态估计问题的有效性。
|
5天前
|
机器学习/深度学习 自然语言处理 算法
m基于深度学习的OFDM+QPSK链路信道估计和均衡算法误码率matlab仿真,对比LS,MMSE及LMMSE传统算法
**摘要:** 升级版MATLAB仿真对比了深度学习与LS、MMSE、LMMSE的OFDM信道估计算法,新增自动样本生成、复杂度分析及抗频偏性能评估。深度学习在无线通信中,尤其在OFDM的信道估计问题上展现潜力,解决了传统方法的局限。程序涉及信道估计器设计,深度学习模型通过学习导频信息估计信道响应,适应频域变化。核心代码展示了信号处理流程,包括编码、调制、信道模拟、降噪、信道估计和解调。
28 8
|
7天前
|
算法
基于GA遗传优化的混合发电系统优化配置算法matlab仿真
**摘要:** 该研究利用遗传算法(GA)对混合发电系统进行优化配置,旨在最小化风能、太阳能及电池储能的成本并提升系统性能。MATLAB 2022a用于实现这一算法。仿真结果展示了一系列图表,包括总成本随代数变化、最佳适应度随代数变化,以及不同数据的分布情况,如负荷、风速、太阳辐射、弃电、缺电和电池状态等。此外,代码示例展示了如何运用GA求解,并绘制了发电单元的功率输出和年变化。该系统原理基于GA的自然选择和遗传原理,通过染色体编码、初始种群生成、适应度函数、选择、交叉和变异操作来寻找最优容量配置,以平衡成本、效率和可靠性。
|
8天前
|
机器学习/深度学习 算法
基于鲸鱼优化的knn分类特征选择算法matlab仿真
**基于WOA的KNN特征选择算法摘要** 该研究提出了一种融合鲸鱼优化算法(WOA)与K近邻(KNN)分类器的特征选择方法,旨在提升KNN的分类精度。在MATLAB2022a中实现,WOA负责优化特征子集,通过模拟鲸鱼捕食行为的螺旋式和包围策略搜索最佳特征。KNN则用于评估特征子集的性能。算法流程包括WOA参数初始化、特征二进制编码、适应度函数定义(以分类准确率为基准)、WOA迭代搜索及最优解输出。该方法有效地结合了启发式搜索与机器学习,优化特征选择,提高分类性能。
|
4天前
|
机器学习/深度学习 存储 算法
基于SFLA算法的神经网络优化matlab仿真
**摘要:** 使用MATLAB2022a,基于SFLA算法优化神经网络,降低训练误差。程序创建12个神经元的前馈网络,训练后计算性能。SFLA算法寻找最优权重和偏置,更新网络并展示训练与测试集的预测效果,以及误差对比。SFLA融合蛙跳与遗传算法,通过迭代和局部全局搜索改善网络性能。通过调整算法参数和与其他优化算法结合,可进一步提升模型预测精度。