117.info
人生若只如初见

c语言如何查找非重复子串个数

要查找一个字符串中非重复子串的个数,可以使用一个哈希表来记录每个字符最后出现的位置,然后使用滑动窗口的方法来遍历整个字符串。

具体步骤如下:

  1. 初始化一个哈希表,用来记录每个字符最后出现的位置,初始值为-1。
  2. 定义一个变量count来记录非重复子串的个数,初始值为0。
  3. 使用两个指针i和j来构建滑动窗口,初始时i和j均指向字符串的开头。
  4. 遍历字符串,将当前字符更新到哈希表中,并将j指针向右移动。
  5. 如果当前字符在哈希表中的位置大于等于i,说明当前字符在滑动窗口中已经出现过,需要更新i指针为当前字符上一次出现的位置的下一个位置。
  6. 更新count为当前滑动窗口的长度。
  7. 返回count作为非重复子串的个数。

下面是使用C语言实现的代码示例:

#include 

int nonRepeatSubstringCount(char* s) {
    int lastPos[128]; // 记录每个字符最后出现的位置
    int i, j, count;
    
    for (i = 0; i < 128; i++) {
        lastPos[i] = -1;
    }
    
    i = 0;
    j = 0;
    count = 0;
    
    while (s[j] != '\0') {
        if (lastPos[s[j]] >= i) {
            i = lastPos[s[j]] + 1;
        }
        
        lastPos[s[j]] = j;
        
        count += j - i + 1;
        
        j++;
    }
    
    return count;
}

int main() {
    char str[] = "abcabcbb";
    int count = nonRepeatSubstringCount(str);
    
    printf("Non-repeating substring count: %d\n", count);
    
    return 0;
}

以上代码示例中,非重复子串的个数为9,分别为"abc", “bca”, “cab”, “abc”, “bc”, “b”, “ca”, “ab”, “abc”。

未经允许不得转载 » 本文链接:https://www.117.info/ask/fe9e7AzsIBAJRB1Y.html

推荐文章

  • C语言编译软件怎么安装和配置

    C语言编译软件通常是指编译器,比如常用的gcc。下面是gcc的安装和配置步骤: 安装gcc
    在Linux系统中,可以通过包管理工具直接安装gcc,比如在Ubuntu中可以使...

  • c语言的字符串如何定义

    在C语言中,字符串通常是以字符数组的形式定义的。可以使用字符数组来存储字符串,数组中的每个元素都是一个字符,最后一个元素为’\0’表示字符串的结束。

  • c语言运行显示此文件不存在怎么办

    如果在运行C语言程序时提示"文件不存在",有几种可能的原因和解决方法: 检查文件路径是否正确:确保程序正确指定了要打开的文件路径。如果文件路径有误,程序会...

  • c语言显示无法执行程序怎么解决

    如果C语言程序无法执行,可以尝试以下解决方法: 检查程序代码:确认程序代码是否有语法错误或逻辑错误,可能影响程序的执行。 编译程序:使用C语言编译器将程序...

  • c语言怎么限制乱码输出信息

    在C语言中,可以通过以下方法来限制乱码输出信息: 使用合适的字符编码:确保程序中使用的字符编码和输出环境的字符编码一致,避免字符编码不匹配导致的乱码问题...

  • 3cdaemon syslog显示乱码怎么解决

    如果3cdaemon的syslog显示乱码,可能是因为字符编码设置不正确或者日志文件本身包含了非标准字符。您可以尝试以下解决方法: 检查3cdaemon的字符编码设置,确保其...

  • mfc怎么获取radio选中的值

    在MFC中,要获取radio按钮选中的值,可以使用GetCheck()函数来获取。以下是一个简单的示例:
    假设有两个radio按钮,分别是IDC_RADIO1和IDC_RADIO2,可以通过...

  • mfc编辑框赋值的方法是什么

    要给MFC编辑框赋值,可以使用以下方法: 使用SetWindowText函数:可以使用该函数将文本内容直接设置到编辑框中,示例代码如下: CString strText = _T("Hello, W...