統(tǒng)計(jì)單詞個(gè)數(shù)C語(yǔ)言函數(shù) c語(yǔ)言統(tǒng)計(jì)個(gè)數(shù)的函數(shù)

C語(yǔ)言統(tǒng)計(jì)單詞個(gè)數(shù),單詞個(gè)數(shù)算法

當(dāng)字符從' '變?yōu)樽帜笗r(shí)或其他字符時(shí)word從0變?yōu)?,而word從0變?yōu)?時(shí)就是一個(gè)單詞,所以count+1;當(dāng)字符由非' '變?yōu)? '時(shí)word從1變?yōu)?,準(zhǔn)備判斷下一個(gè)單詞的出現(xiàn),即等待字符由' '變?yōu)槠渌址某霈F(xiàn)。這樣最后count就是記錄了單詞的個(gè)數(shù),其實(shí)就是記錄了字符由' '變?yōu)槠渌址拇螖?shù)!

網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)公司!專注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、微信小程序定制開發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶創(chuàng)新互聯(lián)還提供了華安免費(fèi)建站歡迎大家使用!

C語(yǔ)言統(tǒng)計(jì)英語(yǔ)單詞的個(gè)數(shù)

C語(yǔ)言:統(tǒng)計(jì)輸入的一行英文句子中的字母及單詞個(gè)數(shù),帶注解!

//通過鍵盤輸入一行英文句子,統(tǒng)計(jì)其中的英文字母和單詞的數(shù)量,單詞之間用空格分開(標(biāo)點(diǎn)符號(hào)不算單詞);

#includestdio.h?

#includestring.h

#includestdlib.h

main()

{

char string[100];//根據(jù)擬從鍵盤輸入的字串的長(zhǎng)度需要適當(dāng)調(diào)整,要避免輸入的長(zhǎng)度超出設(shè)定的范圍。

char c;

int i, num=0,sum=0,word=0; //定義 word 用來(lái)指示一個(gè)單詞是不是結(jié)束或新單詞是否開始;

printf("請(qǐng)從鍵盤輸入一行需要查詢的英文句子,進(jìn)行單詞數(shù)量統(tǒng)計(jì):\n\n");

gets(string);?? //從鍵盤獲得輸入的字符串;

//以下統(tǒng)計(jì)句子中的英文字符個(gè)數(shù);

for(i=0;(c=string[i])!='\0';i++) //for循環(huán)語(yǔ)句,遍歷句子中的每個(gè)字符;初始化i=0;若字符c!='\0',即未到達(dá)結(jié)束符'\0'的話,執(zhí)行i++;

{

if(('A'=string[i]string[i]='Z')||('a'=string[i]string[i]='z'))

sum++;? //以上為條件句,如果字符在A~Z,a~z 范圍之內(nèi)的話,則執(zhí)行sum++,累加英文字母?jìng)€(gè)數(shù);

}

//以下統(tǒng)計(jì)句子中的英文單詞個(gè)數(shù);

for(i=0;(c=string[i])!='\0';i++) //for循環(huán)語(yǔ)句,遍歷句子中的每個(gè)字符;初始化i=0;若字符c!='\0',即未到達(dá)結(jié)束符'\0'的話,執(zhí)行i++;

{????????????????????????????? //'\0'用作字符串的結(jié)束符。它的ASCII數(shù)值是0。

if(c'A'||c'Z'c'a'||c'z')?? //設(shè)定條件:如果字符 c 遇到A~Z和a~z范圍之外其它符號(hào)字符的話,包括遇到空格' ';

word=0;????? //上面條件為真時(shí),執(zhí)行這里,置word=0,表示未遇到單詞,或,一個(gè)單詞已結(jié)束,同時(shí)也意味著要開始遇到下一個(gè)新單詞;

else if(word==0)? //當(dāng)條件(word==0)為真,執(zhí)行下面花括號(hào)里面的語(yǔ)句;當(dāng)word==0時(shí),表示未遇到字母,即未遇到單詞,或上一個(gè)單詞已結(jié)束;

{

word=1;?? //那么置word=1,即,表示下一個(gè)新單詞開始,

num++;?? //執(zhí)行num++,累加英文單詞的個(gè)數(shù);

}

}

printf("\n");

printf("您輸入的這句英文句子中共包含%d個(gè)英文字符,%d個(gè)英文單詞。\n",sum,num);

}

示例:輸入語(yǔ)句:? Hello ! My friend , how are you ? (注意單詞的前后有空格)

C語(yǔ)言進(jìn)階:[14]統(tǒng)計(jì)單詞個(gè)數(shù)

對(duì)一段英文文章進(jìn)行單詞統(tǒng)計(jì),如果剛接觸這樣的問題,感覺比較棘手。要把問題分解開,每一個(gè)小問題解決了,然后進(jìn)行歸并,大問題也就解決了。首先單詞是以字符開始,并且連續(xù)個(gè)字符,直到下一個(gè)字符不是字符結(jié)束,并且這個(gè)字符不能是數(shù)字字符。核心問題就是找出一個(gè)單詞。

查找單詞的代碼如下:

首先查詢到第一字符,有可能是單詞,然后連續(xù)查找字符,直到遇到第一個(gè)不是字符的字符,并且這個(gè)字符在本編程中是空字符和標(biāo)點(diǎn)符號(hào),還得考慮遇到字符串結(jié)束符\0。在代碼中難得部分是字符串指針的處理即返回的是下一個(gè)可能是單詞的查找開始位置。例如

h ?e ?l ?l ?o? 空格??w ?o ?r ?l ? d

0 ?1 ?2 ?3 ?4 ? ?5 ??6 ?7 ?8 ?9 ? 10

第一次查找,i值指向了空格即i=5,傳過來(lái)的索引j指向h,即索引為0,那么結(jié)果j應(yīng)該指向空格即j=5,表達(dá)式為j= j+ (i-(e的索引)1 + 1(數(shù)量差一)) = j+ i。主程序代碼是:

主程序主要是調(diào)用單詞查找函數(shù),每次更新索引值,直到字符串查找完畢。

結(jié)果如下:

該程序的缺點(diǎn)是沒有統(tǒng)計(jì)單詞的開始和結(jié)束位置。

C語(yǔ)言統(tǒng)計(jì)單詞個(gè)數(shù)問題!

根據(jù)英語(yǔ)的書寫習(xí)慣,在每個(gè)單詞前后都會(huì)有空格分隔。 所以可以依據(jù)空格來(lái)劃分單詞。

不過,由于空格可能存在連續(xù)多個(gè),所以僅統(tǒng)計(jì)空格數(shù)是不可以的,需要更復(fù)雜一些的算法。

一、算法設(shè)計(jì):

核心思想是通過一個(gè)flag,來(lái)確定單詞的起始, 每出現(xiàn)一個(gè)單詞的起始,則表示存在一個(gè)單詞。 這樣統(tǒng)計(jì)出現(xiàn)的單詞起始個(gè)數(shù),即可獲得單詞總數(shù)。

1、flag初始為1;

2、遍歷字符串。

3、對(duì)于每個(gè)字符,如果出現(xiàn)非空格字符,且flag為1,則為單詞起始,累加計(jì)數(shù)器。同時(shí)賦值flag為0。

4、在flag為0情況下,如果出現(xiàn)空格,表示上一個(gè)單詞已經(jīng)結(jié)束,設(shè)置flag為1。

5、 遍歷結(jié)束后輸出結(jié)果。

二、參考代碼:

#include?stdio.h

int?func(char?*s)//計(jì)算單詞數(shù)函數(shù)

{

int?i,n=0,flag=1;

for(i?=?0;?s[i];?i?++)//遍歷

{

if(flag?==?1)

{

if(s[i]?!=?'?')//單詞起始

{

n++;

flag?=?0;

}

}

else?if(s[i]?==?'?')//上一個(gè)單詞結(jié)束。

flag?=?1;

}

return?n;//返回結(jié)果。

}

int?main()

{

char?s[200];

gets(s);//輸入字符串。

printf("%d\n",?func(s));//調(diào)用函數(shù),計(jì)算并輸出結(jié)果。

return?0;

}

C語(yǔ)言統(tǒng)計(jì)單詞個(gè)數(shù)

Q:輸入一串字符串,輸出其中有多少個(gè)單詞。?

Eg:Good Wishes?

A:

#include stdio.h#include string.h#define SIZE 20int main()

{ ? ?char str[SIZE]={'\0'}; ? ?int count=0;

printf("plz input the string\n");

gets(str);

puts(str); ? ?int length = strlen(str); ? ?for (int i=0;ilength;i++)

{

if(str[i]!=' ')

{ ? ? ? ? ? ?count++; ? ? ? ? ? ?while(str[i]!=' 'str[i]!='\0')

{

i++;

}

}

}

printf("%d\n",count); ? ?return 0;

}

‘\0’和‘0’的區(qū)別:?

在c語(yǔ)言中,它們都是字符,都用對(duì)應(yīng)的ASCII碼來(lái)存儲(chǔ)。例如第一個(gè)ASCII碼,0,對(duì)應(yīng)字符為(Null),就是 ‘\0’,即空字符。我們?cè)赾語(yǔ)言中判斷一個(gè)字符串是否結(jié)束的標(biāo)志就是看是否遇到‘\0’,如果遇到‘\0’,則表示字符串結(jié)束。字符‘0’和數(shù)字0的區(qū)別:前者是字符常量,后者是整形常量,但是字符常量可以像整數(shù)一樣在程序中參與相關(guān)運(yùn)算。

擴(kuò)展資料

字符串所有字符,如果當(dāng)前字符不為空,單詞數(shù)+1,再嵌套一個(gè)while循環(huán),判斷當(dāng)前單詞是否結(jié)束。

#include stdio.h

#include string.h

int count_words(char* s)

{

int len=strlen(s);

int count,i;

for(i=0;ilen;i++)

{

if(*(s+i)!=' '){ ?// 如果當(dāng)前代碼不為空

count++; ?//單詞數(shù)+1

while(*(s+i)!=' ' ilen) ?//判斷當(dāng)前單詞是否結(jié)束

i++;

}

}

return count;

}

int main()

{

char* a="i love you";

printf("%d",count_words(a));

}

網(wǎng)頁(yè)題目:統(tǒng)計(jì)單詞個(gè)數(shù)C語(yǔ)言函數(shù) c語(yǔ)言統(tǒng)計(jì)個(gè)數(shù)的函數(shù)
網(wǎng)址分享:http://muchs.cn/article24/dogicje.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站改版小程序開發(fā)、自適應(yīng)網(wǎng)站、企業(yè)建站、App設(shè)計(jì)網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都網(wǎng)頁(yè)設(shè)計(jì)公司