打印出给定字符串中既是该字符串前缀又是该字符串后缀的最长部分,在C程序中

打印出给定字符串中既是该字符串前缀又是该字符串后缀的最长部分,在c程序中

给定一个字符串,我们必须检查最长前缀的长度,它也是字符串的后缀,就像有一个字符串“abcab”,所以这里“ab”的长度为2,是最长的子字符串相同的前缀和后缀。

示例

Input: str[] = { “aabbccdaabbcc” }Output: 6Input: abdabOutput: 2

如果我们从字符串的开头和结尾开始指针,那么它们会在某个点重叠,所以我们不会这样做,而是从中间断开字符串并开始匹配左右字符串。如果它们相等,则任何一个匹配字符串的返回大小相同,否则尝试两侧的长度较短。

算法

int longest(char str[], int n)STARTSTEP 1 : DECLARE length AS 0 AND i AS n/2STEP 2 : IF n < 2 THEN   RETURN 1STEP 3 :LOOP WHILE TILL str[i]!=''   IF str[i] == str[length] THEN,      INCREMENT length BY 1      INCREMENT i BY 1   ELSE      IF length == 0 THEN,         INCREMENT i BY 1      ELSE         DECREMENT length BY 1      END IF   END IFEND WHILERETURN lengthSTOP

示例

#include int longest(char str[], int n){   int length = 0, i = n/2;   if( n < 2 )      return 1;   while( str[i]!='' ){      //When we find the character like prefix in suffix,      //we will move the length and i to count the length of the similar prefix and suffix      if (str[i] == str[length]){         ++length;         ++i;      } else //When prefix and suffix not equal{         if(length == 0)            ++i;         else            --length;      }   }   return length;}int main(int argc, char const *argv[]){   char str[] = {"abccmmabcc"};   int n = sizeof(str)/sizeof(str[0]);   int length = longest(str, n);   printf("Length = %d", length);   return 0;}

输出

如果我们运行上面的程序,它将生成以下输出:

Length = 4

以上就是打印出给定字符串中既是该字符串前缀又是该字符串后缀的最长部分,在C程序中的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1445622.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 22:41:21
下一篇 2025年12月17日 22:41:34

相关推荐

  • css之分页打印

    这次给大家带来css之分页打印,css之分页打印的注意事项有哪些,下面就是实战案例,一起来看一下。 很久没写文章了,最近做了一个员工入职的项目,该系统有一个批量打印个人信息的功能需求。因为之前也没接触过打印这方面的功能,就上网查了下,发现jquery有个打印功能的 API(PrintArea) ,关…

    2025年12月24日
    000
  • html如何截图_使用HTML5 Canvas实现页面截图【页面】

    可在网页中截取图像的四种方法:一、用html2canvas库前端截图;二、用Canvas+SVG+foreignObject保留复杂CSS样式;三、用Chrome DevTools协议远程截屏;四、用Window.print()配合打印CSS导出PDF。 如果您希望在网页中直接截取当前页面或指定区域…

    2025年12月23日
    000
  • 如何使用JavaScript在不同HTML页面间传递CSS样式值

    本文详细探讨了如何在不同html页面之间传递并持久化css样式值,以实现ui状态的同步。文章首先分析了直接存储dom元素对象导致的问题,随后提出了使用javascript和`localstorage`存储和检索css属性值或样式类名的有效方法。通过提供清晰的代码示例和最佳实践,本教程旨在帮助开发者理…

    2025年12月23日
    000
  • PHP 多语言网站切换:会话管理与翻译函数实践

    本教程详细介绍了使用 php 构建多语言网站的实现方法。文章涵盖了如何通过 url 参数和会话管理实现语言切换,以及如何设计一套健壮的翻译加载与显示机制,以避免常见的变量未定义和字符串偏移错误。通过封装的辅助函数,确保翻译内容正确加载和渲染,提升代码的可维护性和用户体验。 构建多语言网站的核心挑战 …

    2025年12月23日
    300
  • 使用JavaScript和Fetch API动态渲染新闻列表:解决内容覆盖问题

    本教程详细讲解如何利用javascript的fetch api从restful接口获取数据,并动态生成html内容以在网页上展示新闻标题列表。文章将深入探讨在处理数组数据时,如何避免在循环中错误地覆盖dom内容,确保所有数据项都能被正确渲染,从而解决api数据动态渲染时常见的只显示最后一项的问题。 …

    2025年12月23日 好文分享
    000
  • 如何删除html节点_HTML DOM节点删除(removeChild)与内存释放方法

    删除HTML节点的核心方法是removeChild,需通过父节点移除子节点,如parentNode.removeChild(childNode)。现代浏览器也支持更便捷的element.remove()方法,允许节点直接删除自身。节点被移除后虽脱离DOM树,但若JavaScript仍持有其引用(如事…

    2025年12月23日
    100
  • 动态加载图片到Swiper轮播图的正确姿势

    本文详细介绍了如何使用javascript动态加载图片数据并正确填充到swiper轮播图的每个幻灯片中。通过分析常见的错误,如误用`queryselector`和不当的dom操作,教程演示了如何利用`queryselectorall`和适当的迭代方法,确保每张图片都能准确地显示在对应的轮播幻灯片中,…

    好文分享 2025年12月23日
    000
  • 避免HTML硬编码到JS中的方法是什么_避免HTML硬编码到JS中的方法实践

    使用模板字符串、外部模板、模板引擎或前端框架可避免JS中硬编码HTML,提升代码可维护性与安全性。 避免将HTML硬编码到JavaScript中,能提升代码的可维护性、可读性和安全性。直接在JS里拼接HTML字符串虽然简单,但容易出错,也难以调试和扩展。以下是几种实用的方法来解决这个问题。 使用模板…

    2025年12月23日
    000
  • R语言:从HTML页面高效提取并解析内嵌JSON数据

    本教程详细介绍了在R语言中如何从包含JSON数据的HTML网页中提取并解析所需信息。针对rvest无法直接解析内嵌JSON的问题,我们将展示如何利用html_text()获取网页的原始文本内容,再结合jsonlite::parse_json()将其转换为R数据结构,并进一步处理以提取特定嵌套字段,最…

    2025年12月22日
    000
  • HTML表格排序怎么实现_HTML表格JavaScript排序功能教程

    通过JavaScript实现HTML表格排序,核心是监听表头点击事件,获取列数据后按类型(字符串、数字、日期)进行升序或降序排序,并利用DocumentFragment优化DOM操作以提升性能。 HTML表格排序,说白了就是通过JavaScript来动态调整表格行的顺序。这听起来可能有点复杂,但核心…

    2025年12月22日 好文分享
    000
  • 动态创建HTML输入字段、捕获其值并构建动态字符串的JavaScript教程

    本文详细介绍了如何使用JavaScript动态创建HTML输入字段,高效捕获这些动态字段的用户输入值,并利用这些值灵活构建动态字符串。教程将指导读者避免传统变量命名陷阱,转而采用数组和类选择器等现代方法,确保代码的健壮性和可扩展性。 在现代web应用开发中,经常需要根据用户交互动态地添加或移除表单元…

    2025年12月22日
    000
  • 如何在JavaScript中将字符串转换为小写字母?

    要将 JavaScript 中的字符串转换为小写字母,请使用 toLocaleLowerCase() 方法。 示例 您可以尝试运行以下代码来了解如何在 JavaScript 中使用 toLocaleLowerCase() 方法 – 实时演示 var a = “WELCOME!”; doc…

    2025年12月21日
    000
  • 如何添加一个按钮来打印一个HTML页面?

    在 HTML 网页上添加“打印”按钮,单击该按钮后,将打印整个网页。这是在网页中添加的相当简单的功能,可以使用一些 HTML 元素和纯 JavaScript 来添加。 因此,让我们讨论一下这样做的方法。 方法 首先,在 HTML dom 中添加 标签。 将其 type 属性分配给“button”并为…

    2025年12月21日
    000
  • 匹配任何包含零个或多个p的字符串

    要使用 JavaScript RegExp 匹配任何包含零个或多个 p 的字符串,请使用 p* 量词。 示例 您可以尝试运行以下代码来匹配包含零个或多个 p 的任何字符串。这里,p 被认为是出现的次数 – JavaScript Regular Expression var myStr =…

    2025年12月21日
    000
  • 如何将当前语言环境的约定,将日期的“时间”部分作为字符串返回?

    要使用当前语言环境的约定以字符串形式返回日期的“时间”部分,请使用 toLocaleTimeString() 方法。 toLocaleTimeString 方法依赖于格式化日期的底层操作系统。它使用运行脚本的操作系统的格式约定将日期转换为字符串。例如,在美国,月份出现在日期之前 (04/15/98)…

    2025年12月21日
    000
  • JavaScript数组-字符串-数学函数

    这次给大家带来javascript数组-字符串-数学函数,使用javascript数组-字符串-数学函数的注意事项有哪些,下面就是实战案例,一起来看一下。 数组方法里push、pop、shift、unshift、join、split分别是什么作用。push()方法添加一个或多个元素到数组的末尾,并返…

    好文分享 2025年12月21日
    000
  • js中repeat()的使用

    repeat()方法用于将字符串重复指定次数并返回新字符串。例如’Hello’.repeat(3)结果为’HelloHelloHello’;传入小数自动向下取整,负数或无法转换的字符串会报错。 在 JavaScript 中,repeat() 是一个字符…

    2025年12月21日
    000
  • JavaScript输入框数值计算结果的货币格式化显示

    本教程详细介绍了如何利用javascript的`tolocalestring()`方法,将用户输入框中的数值计算结果,如乘积,优雅地格式化为符合特定区域设置的货币形式(例如$9,000),并将其显示在另一个输入框中。文章将涵盖`tolocalestring()`的关键参数及其在实际应用中的配置,帮助…

    2025年12月21日
    000
  • 如何从HTML字符串中高效提取标签的src属性

    <img src="https://img.php.cn/upload/article/001/246/273/175902558447559.jpg" alt="如何从HTML字符串中高效提取标签的src属性”>标签的src属性” …

    好文分享 2025年12月20日
    000
  • 怎么使用JavaScript操作浏览器打印功能?

    答案是利用window.print()结合CSS @media print实现局部打印,通过隐藏非打印元素、调整布局样式,并注意浏览器兼容性问题,确保打印内容清晰完整且用户体验良好。 JavaScript操作浏览器打印功能,核心是利用 window.print() 方法,它会直接触发浏览器的打印对话…

    2025年12月20日
    000

发表回复

登录后才能评论
关注微信