查找子串

来源:https://www.cnblogs.com/106-cyh/archive/2018/04/22/8905755.html
-Advertisement-
Play Games

本題要求實現一個字元串查找的簡單函數。 函數介面定義: 函數search在字元串s中查找子串t,返回子串t在s中的首地址。若未找到,則返回NULL。 裁判測試程式樣例: 輸入樣例1: 輸出樣例1: 輸入樣例2: 輸出樣例2: char *search(char *s, char *t){ char ...


本題要求實現一個字元串查找的簡單函數。

函數介面定義:

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

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

裁判測試程式樣例:

#include <stdio.h>
#define MAXS 30

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

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
分析:一開始的想法是,找到第一個於字串相同的字元,然後迅速比對,尋找以及比對的方式如下:

char *search(char *s, char *t)
{
char *p;
for(;*s!='\0';s++)
{
if(*s==*t)
break;
}
if(*s=='\0')\
return NULL;
p=s;
for(;*t!='\0';t++,s++)
{
if(*t!=*s)
{
break;
}
}
if(*t!='\0')
return NULL;
else
return p;
}

20分得18分,然後就知足了,放棄尋找bug得新年直接結束小測試;剛好位來自甚大得新萌陳老師來我大惠院隨便看看,於是就請教一番,果然這紕漏自己很難想到:只是檢查了一次而已,不小心吐槽了一下:怎麼能只扣2分...言歸正傳,測試bug得輸入如下:

輸入

qwerert

ert

輸出

-1

知道bug了,一切好辦,在原來的基礎上,維護了一下,完整代碼如下:


int is(char *p1,char *p2)
{
char *s=p1,*t=p2;
for(;*t != '\0'||*s != '\0';t++,s++)
{
if(*t!=*s)
{
break;
}
}
if(*t!='\0')
return 0;
else
return 1;
}
char *search(char *s, char *t)
{
char *p;
for(;*s!='\0';s++)
{
if(*s==*t)
{
p=s-1;
if(is(s,t))
break;
else
t++;
}

}
if(*s == '\0')
return NULL;
return p;///´Ë´¦Óиöbug
}

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

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

return 0;
}

帶著滿臉的喜悅,去瞧了黃老師的代碼:吃驚:

char *search(char *s, char *t)
{
int lens=strlen(s);
int lent=strlen(t);
int i,j,k;
int x=lens-lent;
for (i=0; i<=x; i++)
{
for (j=0,k=i; j<lent; j++,k++)
{
if (s[k]!=t[j]) break;
}
if (j==lent)
break;
}
if (i<=x) return s+i;
else return NULL;
}

接下來才是,從該程式中所學知識(通過兩個程式的對比可得):

1.使用兩層迴圈,可極力簡約程式;

2.將字元串的長度顯現出來,最大程度的發揮了數組較之於指針的優點;

3.數組較之於指針的有點是,可明確指向該數組的具體哪個元素,而且首元素地址不會丟失,這樣二層迴圈才能的到支持。

能學到這麼多,足矣。題目來自PTA。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 小程式項目別的頁面初始化拿到的值為兩種狀態,其他頁面拿不到app.js全局globalData下全局的cookie ...
  • 1.首先寫一個遮罩層div,然後再寫一個彈窗的div js代碼:(把jq引進來) 效果: ...
  • CH1 認識HTML HTML和CSS是我們用來創建網頁的語言:HTML是超文本標記語言(HyperText Markup Language)的縮寫,用來建立網頁的結構;CSS是層疊樣式表(Cascading Style Sheet)的縮寫,用來控制HTML的表現。 Web伺服器存儲並提供由HTML ...
  • ​ 前面在看題目的時候 偶然看到 使用parseInt 來進行整數判斷 但是這裡的parseInt是錯誤示範 之後瞭解了一下 發現這和函數 很有研究 先看看 w3c怎麼說這個的 說實話 雖然我沒有比較好的描述,但是覺的他的解釋並不好 看不懂 我們來看看當沒有 radix這個參數的時候 parseIn ...
  • 寫過jquery的可能都知道,jquery裡面可以很方便的使用以下代碼: 而jquery這種調用方式就是鏈式調用。我們可以從上述代碼看出來,如果不使用鏈式調用的話,那麼我們會增加很多重覆的代碼,而且特別冗餘。而通過鏈式調用,我們可以節省很多代碼,並且代碼看起來更加優雅和整潔。那麼,接下來,我們來 ...
  • 訪問者模式是一種將數據操作和數據結構分離的設計模式,可以說是面向數據密集型的一種設計方式,數據的結構相對穩定,有明顯的分層和分類,而對數據對象的相關操作進行分組、分析等二次加工,這些操作都是由訪問者來執行的,而不是將這些放到被訪問的數據對象中,方便了操作方法的擴展。 作用 封裝一些作用於某種數據結構 ...
  • 這個問題在本科的時候就接觸過了,這兩天做筆試題的時候又看到覺得有必要碼一下。 高內聚低耦合,是軟體工程中的概念,是判斷設計好壞的標準,主要是面向對象的設計,看類的內聚性是否高,耦合度是否低。 下文轉至 https://blog.csdn.net/walid1992/article/details/7 ...
  • 今天周六,休息,剛下過雨,有風。 哈哈,像不像古龍的小說。程式員不是機器人,不是國家總理,沒有那麼忙。而老闆講究的永遠是利益,利用,所以當你沒利用價值的時候,看老闆能閑養你三個月嗎?程式員的賺錢工具就是技術,別人無法替代的技術。天天休息不好,失眠,心亂,只能寫篇博客靜靜心。 在面向對象中,每個對象都 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...