追月的彩云

追月的彩云的笔记

来自学了C语言,如何写个程序统计一篇英文文章中的单词数?(0)

 #include <stdio.h> #include <string.h> int main()// 假设需要统计的字符串都保存在str字符数组中9: char str[128] = "I really love jiawei";// 用于保存空格字符数的变量int num = 0; // 循环遍历整个字符数组,统计空格字符数int i = 0; while('\0' != str[i]) { // 判断当前字符是否是空格,如果是,则统计在内 if(' ' == str[i]) { ++num; // 空格数加1 } ++i; // 检查下一个字符 } // 输出字符串中的单词数,也就是空格数加1 printf("there are %d words in \"%s\"",num+1,str); return 0;}

来自学了C语言,如何写一个程序统计一篇英文文章中的单词数?(续,处理main()函数的参数使其可以处理命令行参数,同时将main()函数拆分成多个函数)(0)

#include <stdio.h>#include <string.h>#include <stdbool.h>// 读取文件到字符数组bool read(const char* file,char* str){if( NULL == file || NULL == str){return false;}// 以只读方式打开文件FILE* fp = fopen(file,"r");if(NULL!=fp){// 用fgets()函数读取文件char line[128] = "";while(fgets(line,128,fp)!=NULL){// 将读取得到的字符串保存到目标字符数组中strcat(str,line);}// 关闭文件fclose(fp);fp = NULL;return true;}else{printf("cannot open %s.",file);return false;}}int countword(char* text){if(NULL != text){// 循环遍历整个字符数组,统计空格字符以及换行字符数int i = 0;int num = 0; // 空格或换行字符数while('\0' != text[i]){// 判断当前字符是否是空格换行字符,// 如果是,则统计在内if(' ' == text[i] // 空格|| '\n' == text[i]) // 换行{++num; // 总数加1}++i; // 检查下一个字符}return num+1; // 返回单词数目}else{return 0;}}int main(int argc,char* argv[]){if(argc != 2){puts("ARGUMENS ERROR. eg. count demo.txt");return 1;}char text[1028*10] = "";if(read(argv[1],text)){int n = countword(text);// 输出字符串中的单词数,也就是空格数加1printf("there is(are) %d word(s) in the \"%s\"",n,argv[1]);}return 0;}

来自学了C语言,如何写一个程序统计一篇英文文章中的单词数?(根据单词的特征,采用递归的方法统计) (0)

#include <stdio.h>#include <string.h>#include <stdbool.h> // 读取文件到字符数组bool read(const char* file,char* str){if( NULL == file || NULL == str){return false;}// 以只读方式打开文件FILE* fp = fopen(file,"r");if(NULL!=fp){// 用fgets()函数读取文件char line[128] = "";while(fgets(line,128,fp)!=NULL){// 将读取得到的字符串保存到目标字符数组中strcat(str,line);}// 关闭文件fclose(fp);fp = NULL;return true; } else{printf("cannot open %s.",file);return false;}}// 统计字符串中的单词数int countword(char* text){// 寻找单词开始位置// 一直从字符串开始位置向后寻找,// 直到遇到一个字母字符while(!isalpha(*text)){// 如果找到了字符串结束位置,// 意味着整个字符串寻找完毕,// 结束整个递归if('\0' == *text){return 0;}++text; // 查找下一个字符}// 寻找字符串的结尾// 从开始位置一直向后查找// 直到遇到一个非字母字符 while(isalpha(*text)) { // 如果当前字符是字母字符 // 则继续查找下一个字符++text;}// 找到一个单词,向下递归 return 1 + countword(text); }int main(int argc,char* argv[]){if(argc != 2){puts("ARGUMENS ERROR. eg. count demo.txt"); return 1;} char text[1028*10] = "";if(read(argv[1],text)){int n = countword(text);// 输出字符串中的单词数,也就是空格数加1printf("there is(are) %d word(s) in the \"%s\"",n,argv[1]);}return 0;}