查找最长不重复字串

C++实现

输入:GongCheng

输出:GongChe :max length is 7, start from 1 char.

/*
* 查找最长不重复字串
* GC
* 2019-8-25
*/
#include<iostream>
using namespace std;
char* isRepeat(char* p1, char* p2){
	// 查找*p2是否在[p1,p2-1]中,即重复
	// 如果返回p1==p2,则表示未重复,否则返回重复位置
	while (*p1 != *p2) p1++;
	return p1;
}
void findNonRepeatStr(char* p, char* &start_pos, int& length){
	//p: 输入字符串首地址
	//stat_pos: 返回最长不重复字符串首地址
	//length: 最长不重复字符串长度
	char* p1=NULL, *p2=NULL;
	start_pos = p;
	length = 0;
	for (p2 = p + 1; *p2 != '\0'; p2++){
		if ((p1=isRepeat(p, p2)) != p2){//出现了重复字符串
			int tmp_len = p2 - p;
			if (tmp_len > length){
				length = tmp_len;
				start_pos = p;
			}
			p = p1 + 1;
		}
	}
	if (p2 - p > length){
		length = p2 - p;
		start_pos = p;
	}
}
int main(){
	char p[100];
	cin >> p;
	int len = 0;
	char* s = NULL;
	findNonRepeatStr(p, s, len);
	for (int i = 0; i < len; i++){
		cout << s[i];
	}
	cout << " :max length is "<<len<<", start from "<<s-p+1<<" char."<<endl;
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值