这道练习题训练了:

1.结构体数组

2.二分查找

3.指针操作

----

都不难。但非常基础,我认为非常好,做完了记到博客上来,题目见k&R,实现例如以下:

/*
* Practice of struct array. K&R 6-1
* @author : wusuopubupt
* @date : 2014-09-18
*/ #include <stdio.h>
#include <ctype.h>
#include <string.h> #define MAXWORD 100 typedef struct key_{
char *word;
int count;
} key; key key_tab[] = {
{"auto", 0},
{"break", 0},
{"case", 0},
{"char", 0},
{"const", 0},
{"continue", 0},
{"default", 0},
{"for", 0},
{"int", 0},
{"void", 0},
{"while", 0}
}; int getword(char *word, int n);
int binary_search(key key_tab[], char *word, int n);
key *binary_search2(key *key_tab, char *word, int n); int getword(char *word, int n) {
int c;
char *w = word; while(isspace(c = getchar())) {
;
}
if(c != EOF) {
*w++ = c;
}
if(!isalpha(c)) {
*w = '\0';
return c;
}
while(n > 0) {
c = getchar();
if(isalnum(c)) {
*w++ = c;
}
else {
break;
}
n--;
} *w = '\0';
return w[0];
} int binary_search(key key_tab[], char *word, int n) {
int low = 0;
int high = n-1;
int mid;
int result;
while(low <= high) {
mid = (low+high) / 2;
result = strcmp(word, key_tab[mid].word);
if(result < 0) {
high = mid-1;
}
else if(result > 0) {
low = mid + 1;
}
else {
return mid;
}
}
return -1;
} /* implemented with pointer */
key *binary_search2(key *key_tab, char *word, int n) {
key *low = key_tab;
key *high = key_tab + n-1;
key *mid;
int result;
while(low <= high) {
//mid = (low+high) / 2; /* error: can not use pointer+pointer d*/
mid = low + (high-low) / 2; /* pointer + num */
result = strcmp(word, mid->word);
if(result < 0) {
high = mid-1;
}
else if(result > 0) {
low = mid + 1;
}
else {
return mid;
}
}
return NULL;
} int main1() {
int i;
int n_keys = sizeof(key_tab) / sizeof(key_tab[0]);
char word[MAXWORD]; while(getword(word, MAXWORD) != EOF) {
if(isalpha(word[0])) {
if((i = binary_search(key_tab, word, n_keys)) >= 0) {
key_tab[i].count++;
}
}
} i = 0;
while(i < n_keys) {
printf("%s : %d\n", key_tab[i].word, key_tab[i].count);
i++;
} return 0;
} int main() {
int n_keys = sizeof(key_tab) / sizeof(key_tab[0]);
char word[MAXWORD];
key *k = NULL; while(getword(word, MAXWORD) != EOF) {
if(isalpha(word[0])) {
if((k = binary_search2(key_tab, word, n_keys)) != NULL) {
k->count++;
}
}
} int i = 0;
while(i < n_keys) {
printf("%s : %d\n", key_tab[i].word, key_tab[i].count);
i++;
} return 0;
}

github:https://github.com/wusuopubupt/LearningC/blob/master/K%26R/chp6/keyword_count.c

K&amp;R练习题6-1统计关键词出现的次数的更多相关文章

  1. eval(function(p,a,c,k,e,r)解密程序

    以eval(function(p,a,c,k,e,r){e=function(c)开头的js文件是经过加密的 使用下面方法可以对js文件进行加密.解密 步骤:1.新建html页面,内容如下列代码 2. ...

  2. sort +awk+uniq 统计文件中出现次数最多的前10个单词

    实例cat logt.log|sort -s -t '-' -k1n |awk '{print $1;}'|uniq -c|sort -k1nr|head -100 统计文件中出现次数最多的前10个单 ...

  3. collections.Counter类统计列表元素出现次数

    # 使用collections.Counter类统计列表元素出现次数 from collections import Counter names = ["Stanley", &qu ...

  4. Excel中COUNTIFS函数统计词频个数出现次数

    Excel中COUNTIFS函数统计词频个数出现次数   在Excel中经常需要实现如下需求:在某一列单元格中有不同的词语,有些词语相同,有的不同(如图1所示).需要统计Excel表格中每个词语出现的 ...

  5. 学习笔记_过滤器应用_1(分ip统计网站的访问次数)

    分ip统计网站的访问次数 ip count 192.168.1.111 2 192.168.1.112 59 统计工作需要在所有资源之前都执行,那么就可以放到Filter中了. 我们这个过滤器不打算做 ...

  6. 【C语言】统计数组中出现次数超过一半的数字

    //统计数组中出现次数超过一半的数字 #include <stdio.h> int Find(int *arr, int len) { int num = 0; //当前数字 int ti ...

  7. R语言︱数据分组统计函数族——apply族用法与心得

    每每以为攀得众山小,可.每每又切实来到起点,大牛们,缓缓脚步来俺笔记葩分享一下吧,please~ --------------------------- 笔者寄语:apply族功能强大,实用,可以代替 ...

  8. 在hadoop上进行编写mapreduce程序,统计关键词在text出现次数

    mapreduce的处理过程分为2个阶段,map阶段,和reduce阶段.在要求统计指定文件里的全部单词的出现次数时. map阶段把每一个关键词写到一行上以逗号进行分隔.并初始化数量为1(同样的单词h ...

  9. 2019牛客国庆集训派对day1 K题 双向链表练习题 splay区间翻转

    题目链接: 解法: 先建n颗平衡树,合并的时候将a中最右的结点翻转到根节点,b中最左的结点翻转到根节点,对合并后的根节点进行标记. #include <bits/stdc++.h> usi ...

随机推荐

  1. GSAP学习笔记

    GSAP(Green Sock Animation Platform)是一个十分好用的js动画库,据说是as的精简版 以下是学习GSAP的一些笔记:貌似中文的文档不是很多 GSAP notes: tl ...

  2. VC生成lib的_stdcall函数名与mingw生成的不一致

    Qt Creator在Windows系统中,怎样链接VC生成的动态链接库 这个问题曾经困扰了我一整天.我想的是按照VC中的方法,增加include文件,增加lib文件,然后编译即可.谁知链接时总是出现 ...

  3. Javascript 学习 笔记一

    1.操作 HTML 元素        如需从 JavaScript 訪问某个 HTML 元素,您能够使用 document.getElementById(id) 方法.        请使用 &qu ...

  4. WinForm界面中快捷键设置

    这是对整个界面的快捷键的设置,比如查询,保存. 1 protected override bool ProcessCmdKey(ref Message msg, Keys keyData) { if ...

  5. iOS 如何自定义NavigationBar的高度

    UINavigationBar的高度在苹果官方的SDK中是固定的44个点,但是实际项目中我们却有可能遇到这样的情况,如下图: 这样的一个UINavigationBar的高度达到了84个点,这就需要我们 ...

  6. 键盘过滤第一个例子ctrl2cap(4.1~4.4)汇总,测试

    键盘过滤第一个例子ctrl2cap(4.1~4.4)汇总,测试 完整源代码 /// /// @file ctrl2cap.c /// @author wowocock /// @date 2009-1 ...

  7. [Swust OJ 715]--字典序问题(组合数预处理/数位dp)

    题目链接:http://acm.swust.edu.cn/problem/715/ Time limit(ms): 1000 Memory limit(kb): 65535   在数据加密和数据压缩中 ...

  8. BZOJ 1216: [HNOI2003]操作系统( 优先队列 )

    按题意用priority_queue模拟即可 ---------------------------------------------------------------------- #inclu ...

  9. Ajax以及类似百度搜索框的demo

    public class Ajax01 extends HttpServlet{ @Override protected void service(HttpServletRequest request ...

  10. Strange Country II 暴力dfs

    这题点的个数(<=50)有限, 所以可以纯暴力DFS去搜索 //#pragma comment(linker, "/STACK:16777216") //for c++ Co ...