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

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

(10)串

2019-11-11 04:40:32
字體:
來源:轉載
供稿:網友

串是字符串的簡稱。它是一種在數據元素的組成上具有一定約束條件的線性表,即要求組成線性表的所有數據元素都是字符,所以,人們經常這樣定義串:串是一個有窮字符序列。如: 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
精品伊人久久97| 久久精品中文字幕一区| 欧美丝袜一区二区三区| 一区二区欧美在线| 2019亚洲日韩新视频| 亚洲理论在线a中文字幕| 国产日韩精品在线观看| 国产午夜精品麻豆| 91精品免费视频| 亚洲国产精品久久91精品| 狠狠色狠狠色综合日日小说| 欧美日韩精品在线| 亚洲欧美制服综合另类| 欧美精品aaa| 亚洲欧美中文日韩v在线观看| 国产精品大陆在线观看| 亚洲精品久久久久中文字幕欢迎你| 亚洲男人7777| 国产91精品视频在线观看| 国产精品久久久久秋霞鲁丝| 久久99青青精品免费观看| 国产69精品久久久久久| 国产精品久久一| 一区二区三区 在线观看视| 色偷偷88888欧美精品久久久| 久久香蕉国产线看观看网| 伊是香蕉大人久久| 久久久久久久久久婷婷| 在线播放精品一区二区三区| 国产香蕉精品视频一区二区三区| 成人免费黄色网| 成人a免费视频| 综合欧美国产视频二区| 97热在线精品视频在线观看| 国产福利视频一区二区| 欧美性生交大片免费| 久久香蕉国产线看观看网| 日韩av有码在线| 欧美日韩在线视频首页| 亚洲女人被黑人巨大进入| 日韩中文字幕欧美| 国产91对白在线播放| 91老司机在线| 亚洲男人天天操| 中文字幕亚洲图片| 96sao精品视频在线观看| 国产亚洲一级高清| 97超视频免费观看| 97人人模人人爽人人喊中文字| 一区二区在线免费视频| 北条麻妃一区二区在线观看| 国产日韩欧美一二三区| 欧美性黄网官网| 69久久夜色精品国产7777| 国产精品日日做人人爱| 亚洲国产日韩欧美综合久久| 国产精品久久久久免费a∨大胸| 色综合久综合久久综合久鬼88| 欧美成人午夜视频| 在线观看日韩视频| 国产精品美女在线| 欧美激情一级欧美精品| 国产精品久久激情| 久久成人av网站| 亚洲伊人久久大香线蕉av| 亚洲aaa激情| 91久久久久久久久久| 精品国产91久久久| 最新国产精品拍自在线播放| 成人黄色大片在线免费观看| 欧美日韩精品在线| 九九热99久久久国产盗摄| 98午夜经典影视| 日本最新高清不卡中文字幕| 国产ts人妖一区二区三区| 亚洲欧美精品伊人久久| 国产精品免费小视频| 在线看片第一页欧美| 久久精品国产69国产精品亚洲| 国产欧美一区二区三区四区| 在线观看日韩视频| 亚洲欧美日韩综合| 亚洲精品中文字| 日韩av在线播放资源| 亚洲欧洲高清在线| 最近2019年日本中文免费字幕| 亚洲xxxxx| 亚洲精品网站在线播放gif| 欧美黄色性视频| 精品女厕一区二区三区| 久久精品久久久久久| 成人免费黄色网| 国产精品亚洲综合天堂夜夜| 不卡毛片在线看| 久久精品国产亚洲精品| 欧美性理论片在线观看片免费| 国产日韩欧美影视| 午夜精品久久久久久久99热浪潮| 日本三级久久久| 亚洲另类欧美自拍| 伊人一区二区三区久久精品| 欧美激情aaaa| 91精品久久久久久久久不口人| 欧美一级片一区| 国产日韩欧美综合| 国产成人免费av电影| 国模精品视频一区二区三区| 国产日韩在线一区| 91色琪琪电影亚洲精品久久| 久久av在线播放| 国产又爽又黄的激情精品视频| 亚洲一二三在线| 国外日韩电影在线观看| 色av中文字幕一区| 国产成人91久久精品| 亚洲天堂av综合网| 久久精品视频在线播放| 久久精品中文字幕一区| 亚洲欧美日韩另类| 国产精品6699| 91地址最新发布| 色综合天天狠天天透天天伊人| 成人在线播放av| 欧美激情一区二区三区久久久| 播播国产欧美激情| 中文字幕亚洲专区| 激情亚洲一区二区三区四区| 最近更新的2019中文字幕| 97在线精品国自产拍中文| 精品偷拍各种wc美女嘘嘘| 亚洲精品国产欧美| 欧美精品在线极品| 欧美大肥婆大肥bbbbb| 日日狠狠久久偷偷四色综合免费| 性欧美暴力猛交69hd| 亚洲色图国产精品| 欧美精品九九久久| 亚洲精品视频网上网址在线观看| 久久综合久久美利坚合众国| 国产精品极品在线| 欧美一级视频一区二区| 国产成人亚洲综合青青| 久久视频精品在线| 亚洲欧美精品一区| 成人中文字幕在线观看| 欧美尺度大的性做爰视频| 日韩欧美aaa| 国产精品www色诱视频| 91美女片黄在线观看游戏| 国产成人综合亚洲| 青青草国产精品一区二区| 国产脚交av在线一区二区| 日韩视频一区在线| 国产剧情日韩欧美| 黄色一区二区在线观看| 亚洲色图50p| 亚洲精品久久久久国产| 久久精品91久久香蕉加勒比| 久久免费视频在线观看| 欧美中文在线字幕| 国产婷婷成人久久av免费高清| 欧美成人激情图片网| 国产一区二区三区在线播放免费观看| 国产精品三级美女白浆呻吟|