亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

(10)串

2019-11-11 05:10:41
字體:
來源:轉載
供稿:網友

串是字符串的簡稱。它是一種在數據元素的組成上具有一定約束條件的線性表,即要求組成線性表的所有數據元素都是字符,所以,人們經常這樣定義串:串是一個有窮字符序列。如: abcdef

串的長度為6

串中沒有任何字符,其串的長度為0,通常稱為空串。由空格字符組成的串,一班稱為空格串。串中任意連續的字符組成的子序列稱為該串的子串。包含子串的串又稱為該子串的主串。子串在主串中第一次出現的第一個字符的位置稱為子串在主串中的位置。兩個串的長度相等,并且各個對應的字符都相同,稱兩個串相等。串的存儲方式也分兩種:串的順序存儲結構和串的鏈式存儲結構

我寫的是一個堆分配存儲的串,代碼:

#include<iostream>#include<string>#include<malloc.h>using namespace std;//串的堆存儲方式typedef struct {	char *str;	int length;}HString;void init(HString  *s) {	s->length = 0;	s->str = NULL;}//串初始化void HStringInit(HString *s) {	char c;	int length;	cout << "請輸入串的長度:" << endl;	cin >> length;	s->length = length;	s->str = (char*)malloc((length+1)*sizeof(char));	for (int i = 0; i < s->length; i++) {		cin >> c;		s->str[i] = c;	}	cout << "初始化成功!" << endl;}//串賦值void HStringAssign(HString *s, HString *t) {				if (s->str) free(s->str);	int len = t->length;	s->length = len;	if (!len) {		s->str = (char*)malloc(sizeof(char));		s->str[0] = '/0';	}	else {		s->str = (char*)malloc(sizeof(char));		for (int i = 0; i < t->length; i++) {			s->str[i] = t->str[i];		}	}	cout << "賦值成功!" << endl;}//輸出串內容void PRint(HString *s) {								if (s->length == 0 && s->str == NULL) {		cout << "串的內容為空!" << endl;	}	else {		cout << "串的內容為:	";		for (int i = 0; i < s->length; i++) {			cout << s->str[i];		}		cout << endl;	}}//求串長void HStringLength(HString *s ) {						cout << "串的長度為:		" << s->length << endl;}//判串相等void HStringCompar(HString *s,HString *t) {					int flag = 0;	if (s->length != t->length) {		cout << "不相等!" << endl;	}	else {		if (s->length == 0) {			cout << "相等!" << endl;		}		else {			for (int i = 0; i < s->length&&i < t->length; i++) {				if (s->str[i] != t->str[i]) {					cout << "不相等!" << endl;					flag = 1;					break;				}			}			if (flag == 0) {				cout << "相等!" << endl;			}		}	}}//串連接void HStringConCat(HString *s,HString *t) {					HString s1;	init(&s1);	int i = 0;	HStringAssign(&s1, s);	s->length += t->length;	free(s->str);	s->str = (char*)malloc((s->length+1)*sizeof(char));	for (; i < s1.length; i++) {		s->str[i] = s1.str[i];	}	for (; i < s->length;i++) {		s->str[i] = t->str[i - s1.length];	}	free(s1.str);	free(t->str);	t->str = NULL;	t->length = 0;	cout << "連接完成!" << endl;}//求子串void HStringSub(HString *s,int start,int end) {				cout << "子串為:";	for (int i = start - 1; i < end; i++) {		cout << s->str[i];	}	cout << endl;}//子串定位void HStringIndex(HString *s,HString *t) {					int i = 0,j = 0;	while (i < s->length &&j < t->length) {		if (s->str[i] == t->str[j]) {			i++; 			j++;		}		else {			i = i - j + 1;			j = 0;		}	 }	if (j == t->length) {		cout << "子串的位置為:" << i-t->length + 1 << endl;	}	else {		cout << "沒有該子串!" << endl;	}}//串置換void HStringReplace(HString *s,HString *t) {			HString s1;	init(&s1);	HStringAssign(&s1, s);	HStringAssign(s, t);	HStringAssign(t, &s1);	free(s1.str);	s1.length = 0;	s1.str = NULL;	cout << "置換成功!" << endl;}//插入子串void HStringInsert(HString *s,int start,HString *t) {		HString s1;	init(&s1);	int i = 0,j;	HStringAssign(&s1, s);	s->length += t->length;	free(s->str);	s->str = (char*)malloc((s->length + 1) * sizeof(char));	for (; i < start-1; i++) {		s->str[i] = s1.str[i];	}	j = i;	for (int k = 0; k < t->length; k++, i++) {		s->str[i] = t->str[k];	}	for (; i < s->length; i++, j++) {		s->str[i] = s1.str[j];	}	cout << "插入成功!" << endl;}//刪除子串void HStringDelet(HString *s,int start,int length) {		int i = start,flag,k=length;	char c;	while (length != 0) {		s->str[i - 1] = 0;		length--;		i++;	}	for (int m = 0; m < s->length;m++) {		if (s->str[m] != 0 && s->str[m - 1] == 0) {			flag = m;			while (flag) {				if (s->str[flag - 1] != 0) {					break;				}				c = s->str[flag - 1];				s->str[flag - 1] = s->str[flag];				s->str[flag] = c;				flag--;			}		}	}	s->length -=k;	cout << "刪除成功!" << endl;}void message() {	cout << "************************************************************" << endl;	cout << "*	1  	輸出串          	2	串賦值	   *" << endl;	cout << "*	3	判串相等		4	求串長	   *" << endl;	cout << "*	5	串連接			6	求子串	   *" << endl;	cout << "*	7	子串定位		8	串置換	   *" << endl;	cout << "*	9	插入子串		10	刪除子串   *" << endl;	cout << "*	11	清屏			12	退出	   *" << endl;	cout << "************************************************************" << endl;}void main() {	int temp = 0,length;	HString S1, S2;	message();	cout << "對串S1進行初始化:" << endl;	HStringInit(&S1);	cout << "對串S2進行初始化:" << endl;	HStringInit(&S2);	int i = 0;	while (1) {				cin >> i;		switch (i) {		case 1:cout << "請輸入你要輸出的串    1:  S1,    2:   S2" << endl;										cin >> temp;					switch (temp) {							case 1:print(&S1); break;							case 2:print(&S2); break;							default:cout << "輸入錯誤!" << endl; break;					}				break;		case 2:	cout << "將S2賦值給S1" << endl;					HStringAssign(&S1, &S2);				break;		case 3:cout << "判斷S1和S2是否相等?" << endl;					HStringCompar(&S1, &S2);				break;		case 4:cout << "請輸入你要求的串    1:  S1,    2:   S2" << endl;					cin >> temp;					switch (temp) {							case 1:HStringLength(&S1); break;							case 2:HStringLength(&S2); break;							default:cout << "輸入錯誤!" << endl; break;					}				break;		case 5:cout << "將串S2連接到S1上!" << endl;					HStringConCat(&S1, &S2);				break;		case 6:cout << "求S1的子串:" << endl;				cout << "請輸入開始位置和長度:" << endl;				cin >> temp >> length;				if (temp > S1.length) {					cout << "輸出位置錯誤!" << endl;					break;				}				else {					if ((length - temp) > S1.length) {						cout << "子串長度超出!" << endl;					}					else {						HStringSub(&S1, temp, length);					}				}				break;		case 7:cout << "子串S2在S1中的位置" << endl;			HStringIndex(&S1,&S2);			break;		case 8:cout << "將S1和S2置換!" << endl;				HStringReplace(&S1,&S2);			break;		case 9:cout << "將S2插入到S1中" << endl;				cout << "請輸入插入位置:" << endl;				cin >> temp;				if (temp >= S1.length) {					cout << "插入位置錯誤!" << endl;					break;				}				else {					HStringInsert(&S1,temp,&S2);				}			break;		case 10:cout << "刪除S1的子串:" << endl;				cout << "請輸入開始位置和長度:" << endl;				cin >> temp >> length;				if (temp > S1.length) {					cout << "輸出位置錯誤!" << endl;					break;				}				else {					if ((length + temp) > S1.length+1) {					cout << "子串長度超出!" << endl;					}					else {						HStringDelet(&S1, temp, length);					}				}break;		case 11:system("cls"); message(); break;		case 12:exit(0); break;		default:cout << "輸入錯誤!請重新輸入:" << endl; break;		}	}}


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美一级淫片aaaaaaa视频| 国产成人亚洲综合91精品| 日韩少妇与小伙激情| 国产精品激情av在线播放| 欧美三级欧美成人高清www| 日韩亚洲精品视频| 亚洲性日韩精品一区二区| 欧美性xxxxx极品娇小| 久久久久久久久久国产| 亚洲国产欧美一区二区丝袜黑人| 欧美日韩一区二区三区在线免费观看| 亚洲国产精品99久久| 亚洲男人第一av网站| 日韩中文字幕网址| 午夜精品福利电影| 国外视频精品毛片| 精品国产乱码久久久久久虫虫漫画| 91影视免费在线观看| 色www亚洲国产张柏芝| 国产精品欧美久久久| 中文字幕亚洲天堂| 欧美人在线观看| 亚洲精品国产精品自产a区红杏吧| 91亚洲va在线va天堂va国| 久久久国产精彩视频美女艺术照福利| 亚洲男人av在线| 91手机视频在线观看| 日本欧美黄网站| 91精品国产九九九久久久亚洲| 欧美性69xxxx肥| 亚洲国内高清视频| 亚洲视频在线视频| 狠狠色香婷婷久久亚洲精品| 亚洲天堂第二页| 色综合伊人色综合网| 欧美理论在线观看| 国内免费精品永久在线视频| 欧美在线观看网站| 久久久久女教师免费一区| 欧美肥臀大乳一区二区免费视频| 国产成人精品一区二区三区| 国产视频精品在线| 亚洲人成在线播放| 欧美激情久久久久| 亚洲成人亚洲激情| 亚洲国产精品成人一区二区| 欧美尤物巨大精品爽| 最新中文字幕亚洲| 欧美日韩另类视频| 91午夜理伦私人影院| 中文字幕av一区中文字幕天堂| 国产在线视频欧美| 一区二区欧美亚洲| 日韩成人在线网站| 欧美日韩一区二区精品| 68精品国产免费久久久久久婷婷| 国产成人久久久| 欧美日韩亚洲激情| 色婷婷**av毛片一区| 精品久久久一区| 久久激情视频久久| 国产精品亚洲视频在线观看| 欧美极品少妇全裸体| 欧美视频在线免费看| 川上优av一区二区线观看| 国产日韩欧美在线观看| 色婷婷**av毛片一区| 亚洲精品av在线播放| 亚洲一区999| 久久久久久久一| 亚洲第一区第一页| 亚洲精品国产拍免费91在线| 午夜精品久久久久久久99热浪潮| 亚洲成年网站在线观看| 亚洲电影成人av99爱色| 国产精品美女在线观看| 国产91精品在线播放| www高清在线视频日韩欧美| 亚洲美女精品久久| 国内精品久久久久久影视8| 日韩欧美在线免费| 在线观看日韩av| 欧美中文在线免费| 国产欧美精品在线| 亚洲第一二三四五区| 久久天天躁狠狠躁夜夜躁| 韩曰欧美视频免费观看| 深夜福利国产精品| 亚洲网址你懂得| 欧美在线视频导航| 亚洲专区国产精品| 国内精品在线一区| 一本一本久久a久久精品牛牛影视| 日韩美女av在线| 亚洲欧美中文日韩在线v日本| 秋霞成人午夜鲁丝一区二区三区| 精品久久久久久中文字幕一区奶水| 国产91在线高潮白浆在线观看| 欧美日韩一区二区三区在线免费观看| 中文字幕欧美国内| 亚洲精品日韩欧美| 国产中文日韩欧美| 成人h片在线播放免费网站| 久久久免费在线观看| 久久久久一本一区二区青青蜜月| 久久久久久久av| 成人免费看片视频| 欧美午夜激情视频| 大胆欧美人体视频| 91成人性视频| 中文字幕亚洲一区二区三区五十路| 51精品在线观看| 91亚洲精品在线| 国产精品久久999| 黑人巨大精品欧美一区二区| 欧美大尺度电影在线观看| 69久久夜色精品国产7777| 日韩av电影手机在线| 成人黄色免费网站在线观看| 大桥未久av一区二区三区| 另类天堂视频在线观看| 亚洲精品国产精品国自产在线| 国产成人高清激情视频在线观看| 亚洲片av在线| 亚洲福利在线观看| 欧美成人午夜视频| 一区二区亚洲精品国产| 国产精品视频精品| 日韩av在线免费观看一区| 精品国产91久久久久久老师| 宅男66日本亚洲欧美视频| 国产精品99一区| 欧美性猛交xxxx乱大交3| 久久久久久91香蕉国产| 日韩人体视频一二区| 97超级碰碰碰久久久| 午夜精品美女自拍福到在线| 欧美xxxx18国产| 久久成年人视频| 日韩在线视频免费观看| 久久久久久久影视| 国产专区精品视频| 国产成人精品国内自产拍免费看| 欧美中文字幕视频在线观看| 国产成人综合亚洲| 成人乱色短篇合集| 欧美日韩亚洲激情| 亚洲男人av在线| 国产91在线高潮白浆在线观看| 久久91亚洲人成电影网站| 亚州av一区二区| 中文字幕九色91在线| 91av在线免费观看视频| 亚洲精品福利视频| 日韩在线激情视频| 欧美黄色成人网| 九九热这里只有精品免费看| 久久成人这里只有精品| 国产精品v片在线观看不卡| 欧美壮男野外gaytube| 97av在线视频免费播放| 久久天天躁狠狠躁夜夜躁| 日韩中文在线中文网在线观看| 欧美激情亚洲综合一区|