说实话这个里面有一个scanf的方法挺值得学习的,我之前问了我同学,因为scanf是不读空格的,所以就是说,gets和scanf的灵活运用可以使得你的代码更加简洁。
方法可适用于其他带空格的字符串查找啥的(不适用那种没有空格分割的字符串,我记得之前有一年期末考了)另外204题和207题也是这种类型可以看完去试试。
中间废话比较多,代码直接翻到最后。
一、题目
246.
题目描述:
输入字符串string[N](N≤100),各个单词以空格隔开,单词长度小于等于8,输入单词word[M](M≤8),
在string中查找出相同的单词并统计该单词出现的次数信息,单词不区分大小写,
输出单词和出现次数的信息,数据之间空一格空格。
主函数输入字符串和待统计单词,编写函数count()实现统计和信息输出
输入描述:
输入一行字符以空格隔开各个单词,输入要统计的单词。
输出描述:
输出单词及其出现的次数信息,数据之间空一格。
输入样例:
To be or not to be is a question
to
输出样例:
to 2
顺便我说的那两题大家也可以看看,比较一下,本质上确实是一样的。
207.
标题
单词排序
描述
定义一个二维字符数组str[10][20],行号表示单词序号,列号表示单词最大长度,输入一个正整数N(N≤10),表示单词数,使用函数wd_sort()完成单词的排序,按字母顺序从小到大排列单词,使用指针完成地址传递,主函数完成数组输入和输出。
时间限制
1
内存限制
10000
类别
1
输入说明
输入一个二维字符数组str和一个正整数N,行号表示单词序号,列号表示单词最大长度。
输出说明
格式输出:单词之间空一行。
输入样例
3
word fish egg
输出样例
egg
fish
word
提示
使用指针作形参,实现地址传递。
数组定义后初始化。
使用strcmp()、strcpy()和strlen()函数,头文件string.h。
204.
嘶就是和246一模一样就是246有个大小写不敏感算了我懒得翻了qwq。
二、思路
其实思路都好找就跟其他人想的一样,但是我看了其他文章就基本上用的都是gets然后一个字符一个字符比较,但是我太懒了那么长我懒得慢慢写(╥ω╥`)。
然后我们注意到,scanf是可以跳过空格读取的,还有%s这种输入方法(`Δ´)!
那就按这个输入咯反正不用慢慢拆的。
然后你试了一下,你会发现没有办法换行就直接给你跳出来了对伐。<(`^´)>
然后这个时候你加了一个getchar()!='\n'来帮助你跳出这个输入循环,然后你又试了试,发现结果是错误的,把案例带进去发现了单词统计的次数少了一个(`Δ´)!
然后你拿printf把数组第一行打出来了结果本来应该是To变成了o,你还会疑惑我的第一个字母呢!!!。这就是因为getchar在判断的时候把第一个字母给get进去了,你当然找不到第一个字母了,最后改成for(i=0;i==0||(i>0&&getchar()!='\n');i++)就行了。
为什么我这么清楚呢,对啊为什么我这么清楚呢(╥ω╥`)。/写bug写的出神入化的菜鸡叹息
我不太清楚后面没问题是不是因为getchar把那个空格整走了,这个我真不清楚qwq,总觉得理论上这种空格整走的思想有点问题。
三、代码
#include <stdio.h>
#include <string.h>
char str[101][9];char word[9];
int main()
{
int i,count=0,j;
for(i=0;i==0||(i>0&&getchar()!='\n');i++)//前面有讲中间那个是干啥的
scanf("%s",&str[i]);
j=i;
gets(word);
for(i=0;i<j;i++)
if(strcmp(strlwr(str[i]),word)==0) count++;//比较,因为题目讲了大小写不敏感所以用了strlwr
printf("%s %d",word,count);
}
主要写这种方法还是因为我太懒了(*/∇\*)/完全懒得多打一行代码