真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

字符串匹配之通配符問題--創(chuàng)新互聯(lián)

一串長為M的珠子,珠子的顏色有N種(N<10)。求包含N種顏色的最短連續(xù)珠串。

創(chuàng)新互聯(lián)建站科技有限公司專業(yè)互聯(lián)網(wǎng)基礎(chǔ)服務(wù)商,為您提供成都二樞服務(wù)器租用托管,高防主機,成都IDC機房托管,成都主機托管等互聯(lián)網(wǎng)服務(wù)。

//兩個指針,開始的時候都指向某一個位置,移動前一個指針,直到兩個指針直接包含了所有顏色的珠子。

//此時記下len。

//然后向前移動后面的指針,再調(diào)整最前面的指針,直到重新滿足兩個指針間包含了所有的顏色,比較此時的len和之前的len,取最小值。

//如此移動,直到后面的指針回到起始位置。

//時間復雜度是O(N),空間復雜度是O(1)

#include
using namespace std;
void Search(char* src,char* ch)
{
	int varies = 0;//多少種顏色
	char* begin = src;
	memset(ch, 0, sizeof(char) * 256);
	while (*begin++)
	{
		if (ch[*begin - '0']++ == 0)
		{
			++varies;
		}
	}
	//此時varies存儲共有多少種顏色
	int MinLength = 0;
	int curLength = 0;
	char* prev = src;
	char* cur = src;
	int curVaries = 0;
	char* ret = NULL;
	memset(ch, 0, sizeof(char) * 256);
	while (1)
	{
		curLength = 0;
		curVaries = 0;
		cur = prev;
		memset(ch, 0, sizeof(char) * 256);
		while (curVaries != varies)
		{
			if (++ch[*cur - '0']==1)
			   curVaries++;
			++cur;
			++curLength;
			if (*cur == '\0')
				cur = src;
		}
		if (MinLength == 0 || MinLength > curLength)
		{
			MinLength = curLength;
			ret = prev;
		}
		if (MinLength == varies)
			break;//得到最短的
		++prev;
		if (*prev =='\0')
			break;
	}
	int flag = 1;
	int index = 0;
	for (int i = 0; i < MinLength; ++i)
	{
		if (ret[i] == '\0')
			flag = 0;
		if (flag == 1)
			ch[i] = ret[i];
		else
			ch[i] = src[index++];
	}
	ch[MinLength] = '\0';
}
void Test1()
{
	char* src = "abbcdabcddddacgd";
	char ch[256] = { 0 };
	Search(src,ch);
	cout<

創(chuàng)新互聯(lián)www.cdcxhl.cn,專業(yè)提供香港、美國云服務(wù)器,動態(tài)BGP最優(yōu)骨干路由自動選擇,持續(xù)穩(wěn)定高效的網(wǎng)絡(luò)助力業(yè)務(wù)部署。公司持有工信部辦法的idc、isp許可證, 機房獨有T級流量清洗系統(tǒng)配攻擊溯源,準確進行流量調(diào)度,確保服務(wù)器高可用性。佳節(jié)活動現(xiàn)已開啟,新人活動云服務(wù)器買多久送多久。


本文標題:字符串匹配之通配符問題--創(chuàng)新互聯(lián)
轉(zhuǎn)載源于:http://weahome.cn/article/ggoeo.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部