當前位置:首頁 » 編程語言 » 統計輸入的單詞c語言
擴展閱讀
webinf下怎麼引入js 2023-08-31 21:54:13
堡壘機怎麼打開web 2023-08-31 21:54:11

統計輸入的單詞c語言

發布時間: 2023-05-12 09:06:22

1. c語言:從鍵盤輸入英文文本,統計總共有多少個單詞。要求如下,咋編

代碼文本:

#include "stdio.h"

int main(int argc,char *argv[]){

char s[25];

int w;

printf("胡亂Please enter a text... ");

w=0;

while(scanf("%24s",s)==1 && *s!='#' && s[1]!='#'派做枯)

if(*s>='a' && *s<='z' || *s>='A' &&塵洞 *s<='Z')

w++;

printf("A total of %d word(s) ",w);

return 0;

}

2. C語言統計英語單詞的個數

C語言:統計輸入的一行英文句子中的字母及單詞個數,帶註解!

//通過鍵盤輸入一行英文句子,統計其中的英文字母和單詞的數量,單詞之間用空格分開(標點符號不算單詞);
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
main()
{
char string[100];//根據擬從鍵盤輸入的字串的長度需要適當調整,要避免輸入的長度超出設定的范圍。
char c;
int i, num=0,sum=0,word=0; //定義 word 用來指示一個單詞是不是結束穗鄭芹或新單詞是否開始;
printf("請從鍵盤輸入一行需要查詢的英文句子,進行單詞數量統計: ");
gets(string); //從鍵盤獲得輸入的字元串;
//以下統計句子中的英文字元個數;
for(i=0;(c=string[i])!='';i++) //for循環語句,遍歷句子中的每個字元;初始化i=0;若字元c!='',即未到達結束符''的話,執行i++;
{
if(('A'<=string[i]&&string[i]<='Z')||('a'<=string[i]&&string[i]<='z'))
sum++; //以上為條件句,如果字元在A~Z,a~z 范圍之內的話,則執行sum++,累加英文字母個數;
}
//以下統計句子中的英文單詞個數;
for(i=0;(c=string[i])!='';i++) //for循環語句,遍歷句子中的每個字元;初始化i=0;若字元c!='',即未到達結束符''的話,執行i++;
{ //''用作字元串的結束符。它的ASCII數值是0。
if(c<'A'||c>'Z'&&c<'a'||c>'z') //設定條件:如果字元 c 遇到A~Z和a~z范圍之外其它符號字元的話,包括遇到空格' ';
word=0; //上面條件為真時,執行這里,置word=0,表示未遇到單詞,或,一個單詞已結叢州束,同時也意味著要開始遇到下一個新單詞;
else if(word==0) //當條件(word==0)為真,執行下面花括弧裡面的語句;當word==0時,表示未遇到字母,即未遇到單詞,或上一個單詞已結束;
{
word=1; //那麼置word=1,即,表示下一個新單詞開始,
num++; //執行num++,累加英文單詞的個數;
}
}
printf(" ");
printf("您輸入的這句英文句子中共包含%d個英文字元,%d個英文單詞。 ",sum,num);

}

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

3. C語言 單詞統計

#include <stdio.h>
#include <string.h>
void main()
{
char ch='\0';
char word[1000][20];
int count_word[1000]={0};
int i=0,j=0,k=0,flag=0,total=0,l=0,max,maxno;
printf("請首物輸入一段英文文章,以#標志結束:\n");
while((ch=getchar())!='#')
{
if((ch>='a' && ch<='z') || (ch>='A' && ch<='Z'))
{
if(ch>='A'&& ch<='Z')ch+=32;
flag=0;
word[i][j]=ch;
j++;
}
else
{
flag = 1; //注意修坦芹物改標志。。。。。。。。
}

if(flag==1)
{
total++;
word[i][j]='\0';
count_word[i]++;
for(k=0;k<i;k++)
{
if(strcmp(word[i],word[k])==0)
{
count_word[k]++;
count_word[i]=0;
i--;
break;
}
}
i++;
j=0;
}
}
printf("所要求的單詞為:\n");

printf("-------------------------"讓液);

for(l=0;l<5;l++)
{
max=0;
maxno=0;
for(k=0;k<i;k++)
if(count_word[k]>max)
{
maxno=k;
max=count_word[k];
}
if(max==0)break;
printf("\n%-10s",word[maxno]);

count_word[maxno]=0;
}
getchar();
}

4. c語言統計單詞個數

根據英語的書寫習慣,在每個單詞前後都會有空格分隔。 所以可以依據空格來劃分單詞。

不過,由於空格可能存在連續多個,所以僅統計空格數是不可以的,需要更復雜一些的演算法。

一、演算法設計:

核心思想是通過一個flag,來確定單詞的起始, 每出現一個單詞的起始,則表示存在一個單詞。 這樣統計出現的單詞起始個數,即可獲得單詞總數。

1、flag初始為1;

2、遍歷字元串。

3、對於每個字元,如果出現非空格字元,且flag為1,則為單詞起始,累加計數器。同時賦值flag為0。

4、在flag為0情況下,如果出現空格,表示上一個單詞已經結束,設置flag為1。

5、 遍歷結束後輸出結果。

二、參考代碼:

#include<stdio.h>
intmain()
{
chars[200];
inti,n=0,flag=1;
gets(s);//輸入字元串。
for(i=0;s[i];i++)//遍歷
{
if(flag==1)
{
if(s[i]!='')//單詞起始
{
n++;
flag=0;
}
}
elseif(s[i]=='')//上一個單詞結束。
flag=1;
}
printf("%d ",n);//輸出結果。
return0;
}

5. C語言統計單詞個數

Q:輸入一串字元串,輸出其中有多少個單詞。
Eg:Good Wishes
A:

#include <stdio.h>#include <string.h>#define SIZE 20int main()
{ char str[SIZE]={''}; int count=0;
printf("plz input the string ");
gets(str);
puts(str); int length = strlen(str); for (int i=0;i<length;i++)
{
if(str[i]!=' ')
{ count++; while(str[i]!=' '&&str[i]!='')
{
i++;
}
}
}
printf("%d ",count); return 0;
}

『』和『0』的區別:
在c語言中,它們都是字元,都用對應的ASCII碼來存儲。例如第一個ASCII碼,0,對應字元為(Null),就是 『』,即空字元。我們在c語言中判斷一個字元串是否結束的標志就是看是否遇到『』,如果遇到『』,則表示字元串結束。字元『0』和數字0的區別:前者是字元常量,後者是整形常量,但是字元常量可以像整數一樣在程序中參與相關運算。

(5)統計輸入的單詞c語言擴展閱讀

字元串所有字元,如果當前字元不為空,單詞數+1,再嵌套一個while循環,判斷當前單詞是否結束。

#include <stdio.h>

#include <string.h>

int count_words(char* s)

{
int len=strlen(s);

int count,i;

for(i=0;i<len;i++)

{

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

count++; //單詞數+1

while(*(s+i)!=' '&& i<len) //判斷當前單詞是否結束

i++;

}

}

return count;

}

int main()

{

char* a="i love you";

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

}

6. c語言中輸入單詞 統計其在文本出現的次數

用string讀入,之後用字典樹trie的數據結構,trie的每個節點數據類型的struct中加一個計數的變數即可統計,之後再按順序輸出即可,時間復雜度理想狀態下是o(n),n是字母個數。=
=實在沒時間寫了,你要是不想自己寫,找個標準的trie一改就好了。。