第一种方法
思路:将文件中的字符一个一个读出,然后与 n 作比较。
复制代码 代码如下:
#include <stdio.h>
#include <string.h>
#include <errno.h>
int main(int argc, char *argv[])
{
FILE *fp;
int n = 0;
int ch;
if((fp = fopen(argv[1],"r+")) == NULL)
{
fprintf(stderr,"open file 1.c error! %sn",strerror(errno));
}
while((ch = fgetc(fp)) != EOF)
{
if(ch == 'n')
{
n++;
}
}
fclose(fp);
printf("%dn",n);
return 0;
}
第二种方法
利用fgets。fgets的原型:char *fgets(char *s, int size, FILE *stream);,fgets最多可以读到size-1个字符,剩下的一个是给 预留的,即总要给 预留一位。同时还应注意:fgets遇到 n 时就停止本次读取,如果数组中可以放下 n 那么就读 n ,否则只能下一次读取了,但是可以肯定的是,如果放到下一次读,那么 n 肯定是第一个,从而造成下次只能读到 n ,会自动加上。剩下的内容还得下下次读。这下就找到规律了!即 n 总是在 的前一位上。
复制代码 代码如下:
#include <stdio.h>
#include <string.h>
#include <errno.h>
int main(int argc, char *argv[])
{
FILE *fp;
int n = 0;
char buffer[3];
if((fp = fopen(argv[1],"r+")) == NULL)
{
fprintf(stderr,"open file 1.c error! %sn",strerror(errno));
}
while((fgets(buffer,3,fp)) != NULL)
{
if(buffer[strlen(buffer) -1] == 'n')
{
n++;
}
}
fclose(fp);
printf("%dn",n);
return 0;
}