欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言入門(mén)之查找子串問(wèn)題

 更新時(shí)間:2022年11月14日 11:46:45   作者:Revival_S  
這篇文章主要介紹了C語(yǔ)言入門(mén)之查找子串問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教

C語(yǔ)言查找子串

查找子串

輸入兩個(gè)字符串s和t,在字符串s中查找子串t,輸出起始位置,若不存在,則輸出-1.要求自定義函數(shù)char*  search(char * s,char * t)返回子串t的首地址,若未找到,則返回NULL。試編寫(xiě)相應(yīng)程序。

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

char* search(char*s,char*t)
{	
	int size_t=strlen(t),size_s=strlen(s),T,i,j;
	char *p=NULL;
	for(i=0;i<=(size_s-size_t);i++)
	{
		p=s+i;
		T=1;
		for(j=0;j<size_t;j++)
		{
			if(*p!=*(t+j))
			{
				T=0;
				break;
			}
			p++;
		}
		if(T==1)
			break;
	}
	if(T==0)
		return NULL;
	else
		return s+i;
}



int main()
{
	char *s,*t,*p,ch;
	int count,i;
	while(1) 
	{
		printf("請(qǐng)輸入字符串s:(直接輸入回車(chē)退出)\n");
		s=(char *)malloc(sizeof(char));       //這里使用動(dòng)態(tài)輸入字符串
		count=0;                //內(nèi)存足夠下可以使字符串字符個(gè)數(shù)不受數(shù)組大小限制
		while((ch=getchar())!='\n')
		{
			s[count]=ch;
			count++;
			s=(char *)realloc(s,(count+1)*sizeof(char));
		}
		s[count]='\0';
		if(count==0)                        //程序結(jié)束判斷
		{
			printf("程序運(yùn)行結(jié)束!\n");
			break;
		}
		while(1)                //防止子串輸入字符個(gè)數(shù)超過(guò)s的循環(huán)
		{
			t=(char *)malloc((count+1)*sizeof(char));
		    printf("輸入子串t:\n");
			i=0;
		    while((ch=getchar())!='\n')   //循環(huán)輸入字符來(lái)計(jì)數(shù)
			{
				t[i]=ch;
		    	i++;
			}
			t[i]='\0';
		    if(i>count)
			{
				printf("子串t串長(zhǎng)>s串長(zhǎng),請(qǐng)重新");
				t=(char *)realloc(t,i*sizeof(char));   //保證內(nèi)存成功釋放,重新分配t內(nèi)存
				free(t);
			}
			else
				break;
		}
		if((p=search(s,t))!=NULL)
		{
			printf("起始位置:從第%d個(gè)字符開(kāi)始\n",p-s+1);
	        printf("%s\n\n",p);
		}
		else
		    printf("-1\n\n");     //題目要求沒(méi)有找到則輸出-1
		free(s); 
		free(t);
	}
	return 0;
}

用了malloc和realloc來(lái)實(shí)現(xiàn)動(dòng)態(tài)內(nèi)存分配從而實(shí)現(xiàn)輸入字符個(gè)數(shù)不再受數(shù)組大小限制(內(nèi)存足夠的話),并且考慮到子串t可能因?yàn)槌鰏的個(gè)數(shù)而出錯(cuò)做了個(gè)容錯(cuò)判斷,總體上加了循環(huán)實(shí)現(xiàn)循環(huán)輸入并設(shè)置了一個(gè)退出程序出口。這里所有用動(dòng)態(tài)分配的指針全部都及時(shí)釋放了,不會(huì)因?yàn)檠h(huán)次數(shù)的增多而導(dǎo)致內(nèi)存占用增大。

 由于realloc動(dòng)態(tài)分配操作較慢,此程序還可以做優(yōu)化,比如先開(kāi)辟10字符的空間,每輸入10個(gè)字符后再多開(kāi)辟10字符空間,程序運(yùn)行速度可以比此程序更快。(但對(duì)于這么一點(diǎn)可以忽略不計(jì)( ̄▽ ̄)~*)

 自定義函數(shù)部分使用了從被查找串s第一個(gè)字符開(kāi)始,與t串的字符逐個(gè)比較的方法來(lái)查找,目前也只能想到了這種查找方法。

結(jié)果:

        

C語(yǔ)言查找子串(采用兩個(gè)循環(huán)查找)

題目來(lái)源:浙大PTA

本題要求實(shí)現(xiàn)一個(gè)字符串查找的簡(jiǎn)單函數(shù)。

函數(shù)接口定義

char *search( char *s, char *t );

函數(shù)search在字符串s中查找子串t,返回子串t在s中的首地址。若未找到,則返回NULL。

裁判測(cè)試程序樣例

#include <stdio.h>
#define MAXS 30

char *search(char *s, char *t);
void ReadString( char s[] ); /* 裁判提供,細(xì)節(jié)不表 */

int main()
{
    char s[MAXS], t[MAXS], *pos;

    ReadString(s);
    ReadString(t);
    pos = search(s, t);
    if ( pos != NULL )
        printf("%d\n", pos - s);
    else
        printf("-1\n");

    return 0;
}

/* 你的代碼將被嵌在這里 */

輸入樣例1:
The C Programming Language
ram
輸出樣例1:
10
輸入樣例2:
The C Programming Language
bored
輸出樣例2:
-1

對(duì)于這道題的思路是,在一串

解答

??不用指針的方法

char *search(char *s, char *t)
{
	int i,j;                               /*定義兩個(gè)下標(biāo)變量*/
	int m=0,n1=0,n2=0;                     /*定義m作為開(kāi)關(guān)和計(jì)數(shù)器,n1和n2為計(jì)數(shù)器*/
	while(*t)                              /*計(jì)算t中元素的個(gè)數(shù),用于下面的循環(huán)*/
    {
        t++;
        n1++;
    }
    for(i=0;i<n1;i++) t--;                 /*讓指針t歸位*/
   	while(*s)                              /*計(jì)算s中元素的個(gè)數(shù),用于下面的循環(huán)*/
    {
        s++;
        n2++;
    }
    for(i=0;i<n2;i++) s--;                 /*讓指針s歸位*/
    for(i=0;i<n2;i++)                      /*在n2的范圍內(nèi)開(kāi)啟循環(huán)*/
    {
		if(s[i]==t[0])                     /*當(dāng)s[i]掃描到的元素等于t[0]*/
		{
			for(j=0;j<n1;j++)              /*往后循環(huán)t個(gè)元素,看是否全都一致*/
        	{
        	    if(s[i+j]==t[j])           /*掃描到后一個(gè)元素,如果相等m加上1*/
        	    	m++;
                else m=0;                  /*如果不等,m等于0*/
            }
            if(m!=n1) m=0;                 /*如果相等的數(shù)沒(méi)有達(dá)到t的個(gè)數(shù)(即n1),m歸零*/
            if(m==n1)                      /*如果相等的數(shù)達(dá)到了t的個(gè)數(shù)*/
	    	{   
				for(j=0;j<i;j++) s++;      /*讓s指向第i個(gè)元素*/
		    	return s;                  /*最后返回s的位置*/
	    	}
		}
	}
	if(m==0) return NULL;                  /*沒(méi)有發(fā)現(xiàn)指定字符串*/
}

以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單通訊錄

    C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)單通訊錄

    這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易通訊錄,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • C++ 基礎(chǔ)教程之虛函數(shù)實(shí)例代碼詳解

    C++ 基礎(chǔ)教程之虛函數(shù)實(shí)例代碼詳解

    虛函數(shù)在 c++ 的繼承體系中是一個(gè)非常重要概念,讓我們可以在子類(lèi)中復(fù)寫(xiě)父類(lèi)的方法。這篇文章主要介紹了C++ 基礎(chǔ)教程之虛函數(shù)實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下
    2020-02-02
  • C++ 11新特性之大括號(hào)初始化詳解

    C++ 11新特性之大括號(hào)初始化詳解

    這篇文章主要介紹了C++ 11新特性之大括號(hào)初始化的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用C++具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-08-08
  • C++?Date類(lèi)的具體使用(構(gòu)建,重載等)

    C++?Date類(lèi)的具體使用(構(gòu)建,重載等)

    本文主要介紹了C++?Date類(lèi)的具體使用(構(gòu)建,重載等),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-07-07
  • LintCode-排序列表轉(zhuǎn)換為二分查找樹(shù)分析及實(shí)例

    LintCode-排序列表轉(zhuǎn)換為二分查找樹(shù)分析及實(shí)例

    這篇文章主要介紹了LintCode-排序列表轉(zhuǎn)換為二分查找樹(shù)分析及實(shí)例的相關(guān)資料,需要的朋友可以參考下
    2017-04-04
  • C語(yǔ)言詳細(xì)講解strcpy strcat strcmp函數(shù)的模擬實(shí)現(xiàn)

    C語(yǔ)言詳細(xì)講解strcpy strcat strcmp函數(shù)的模擬實(shí)現(xiàn)

    這篇文章主要介紹了怎樣用C語(yǔ)言模擬實(shí)現(xiàn)strcpy與strcat和strcmp函數(shù),strcpy()函數(shù)是C語(yǔ)言中的一個(gè)復(fù)制字符串的庫(kù)函數(shù),strcat()函數(shù)的功能是實(shí)現(xiàn)字符串的拼接,strcmp()函數(shù)作用是比較字符串str1和str2是否相同
    2022-05-05
  • C++11如何實(shí)現(xiàn)無(wú)鎖隊(duì)列

    C++11如何實(shí)現(xiàn)無(wú)鎖隊(duì)列

    這篇文章主要介紹了C++11如何實(shí)現(xiàn)無(wú)鎖隊(duì)列,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-08-08
  • C#桌面應(yīng)用開(kāi)發(fā)實(shí)現(xiàn)番茄定時(shí)器

    C#桌面應(yīng)用開(kāi)發(fā)實(shí)現(xiàn)番茄定時(shí)器

    本文主要介紹了C#桌面應(yīng)用開(kāi)發(fā)實(shí)現(xiàn)番茄定時(shí)器,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2024-07-07
  • 字符串拷貝函數(shù)memcpy和strncpy以及snprintf 的性能比較

    字符串拷貝函數(shù)memcpy和strncpy以及snprintf 的性能比較

    以下是對(duì)字符串拷貝函數(shù)memcpy和strncpy以及snprintf它們之間的性能進(jìn)行了比較,需要的朋友可以過(guò)來(lái)參考下
    2013-07-07
  • C語(yǔ)言實(shí)現(xiàn)從指定位置截取文件內(nèi)容

    C語(yǔ)言實(shí)現(xiàn)從指定位置截取文件內(nèi)容

    這篇文章主要為大家詳細(xì)介紹了如何利用C語(yǔ)言實(shí)現(xiàn)從指定位置截取文件內(nèi)容,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-11-11

最新評(píng)論