Q:輸入一串字符串,輸出其中有多少個(gè)單詞。?
創(chuàng)新互聯(lián)是專業(yè)的平武網(wǎng)站建設(shè)公司,平武接單;提供成都做網(wǎng)站、成都網(wǎng)站制作,網(wǎng)頁(yè)設(shè)計(jì),網(wǎng)站設(shè)計(jì),建網(wǎng)站,PHP網(wǎng)站建設(shè)等專業(yè)做網(wǎng)站服務(wù);采用PHP框架,可快速的進(jìn)行平武網(wǎng)站開發(fā)網(wǎng)頁(yè)制作和功能擴(kuò)展;專業(yè)做搜索引擎喜愛的網(wǎng)站,專業(yè)的做網(wǎng)站團(tuán)隊(duì),希望更多企業(yè)前來合作!
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碼來存儲(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));
}
給你提供一個(gè)庫(kù)函數(shù)
相信不難解決
char *strtok(char *s, char *delim);
#include?stdio.h
int?main(void)
{
char?c;?//記錄輸入的每一個(gè)字符
int?count,?word;?//count統(tǒng)計(jì)單詞的個(gè)數(shù)?
int?repeat,?ri;?
scanf("%d",?repeat);
getchar();
for(ri?=?1;?ri?=?repeat;?ri++){
c?=?getchar();
count?=?0;?????//初始化計(jì)數(shù)器0
while(c=='?')??
c=getchar();//這個(gè)循環(huán)體用于過濾掉句子前面的空格,即第一個(gè)單詞前的空格
while?(c!='\n')?
{?
while?(c!='?'??c!='\n')?
c=getchar();?//當(dāng)輸入的字符不為空,并且不是換行符時(shí),持續(xù)輸入,對(duì)于一個(gè)單詞而言,空格或者換行符均可作為其標(biāo)志
count++;?//找到一個(gè)即增加一個(gè)技術(shù)
while?(c=='?'??c!='\n')?
c=getchar();?//過濾掉該單詞后的所有空格
}?
printf("count?=?%d\n",?count);?//最后輸出單詞個(gè)數(shù)
}
}
我覺得關(guān)鍵在于,對(duì)單詞的計(jì)數(shù)標(biāo)志是關(guān)鍵:
當(dāng)輸入的字符不為空格時(shí),表示?我輸入的是一個(gè)單詞;
當(dāng)輸入空格或者換行符時(shí),表示我輸入的是另一個(gè)單詞,此時(shí)計(jì)數(shù)器應(yīng)加一
當(dāng)輸入的是換行符時(shí),表示輸入結(jié)束,此時(shí)應(yīng)停止計(jì)數(shù),輸出結(jié)果
根據(jù)英語(yǔ)的書寫習(xí)慣,在每個(gè)單詞前后都會(huì)有空格分隔。 所以可以依據(jù)空格來劃分單詞。
不過,由于空格可能存在連續(xù)多個(gè),所以僅統(tǒng)計(jì)空格數(shù)是不可以的,需要更復(fù)雜一些的算法。
一、算法設(shè)計(jì):
核心思想是通過一個(gè)flag,來確定單詞的起始, 每出現(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ù),帶注解!
//通過鍵盤輸入一行英文句子,統(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 用來指示一個(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,傳過來的索引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é)束位置。