在C语言中,字符串中任意两个相同字符之间的最大字符数

2023年 9月 17日 47.9k 0

在C语言中,字符串中任意两个相同字符之间的最大字符数

我们得到一个字母字符串。数组中至少会有两个相同字符的出现。这里的任务是找到任意两个相同字符之间的最大字符数。如果没有任何字符的重复,则返回-1。

输入 - 字符串 str = "abcdba"

输出 - 字符串中任意两个相同字符之间的最大字符数 - 4

解释 - 重复的字符只有'a'和'b',它们的索引为-

1. 2‘a’ first index 0 last 5 , characters in between 5-0-1=4
2. ‘b’ first index 1 last 4 , characters in between 4-1-1=2
   Maximum character in between repeating alphabets : 4

登录后复制

输入 - 字符串 str = “AbcAaBcbC”

输出 - 字符串中任意两个相同字符之间的最大字符数 - 5

解释 - 重复的字符是 ‘A’,‘b’,‘c’,它们的索引如下:

1. ‘A’ first index 0 last 3 , characters in between 3-0-1=2
2. ‘b’ first index 1 last 7 , characters in between 7-1-1=5
3. ‘c’ first index 2 last 6 , characters in between 6-2-1=3
   Maximum character in between repeating alphabets : 5

登录后复制

Note − 如果输入字符串为 “abcdefg” ,则没有重复字符,因此函数将返回-1。

下面程序中使用的方法如下

  • 我们使用一个字符数组来存储字符串 Str[]

  • 函数 maxChars( char str[],int n) 用于计算任意两个重复字母之间的最大字符数。

  • 我们将变量 maxC 初始化为-1。

  • 在 for 循环中从字符串的开头遍历数组。

  • 在嵌套的 for 循环中遍历剩余的字符,并搜索是否有重复字符(如果 str[i] == str[j])。

  • 如果为真,则通过减去索引计算字符之间的差异(temp = j - i - 1)。

  • 如果这个值是迄今为止找到的最大值,则将其存储在 maxC 中。

  • 在遍历整个字符串后,返回 maxC。

示例

 演示

#include
#include
#include
int maxChars(char str[],int n){
   int size = n;
   int maxC = -1;
   for (int i = 0; i temp?maxC:temp;
         }
   return maxC;
}
// Driver code
int main(){
   char Str[] = "AbcAaBcbC";
   printf("Maximum number of characters between any two same character in a string :%d",
   maxChars(Str,9) );
   return 0;
}

登录后复制

输出

如果我们运行上面的代码,它将生成以下输出 −

Maximum number of characters between any two same character in a string : 5

登录后复制

以上就是在C语言中,字符串中任意两个相同字符之间的最大字符数的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!

相关文章

JavaScript2024新功能:Object.groupBy、正则表达式v标志
PHP trim 函数对多字节字符的使用和限制
新函数 json_validate() 、randomizer 类扩展…20 个PHP 8.3 新特性全面解析
使用HTMX为WordPress增效:如何在不使用复杂框架的情况下增强平台功能
为React 19做准备:WordPress 6.6用户指南
如何删除WordPress中的所有评论

发布评论