Description

在英文文献中,尤其是专业文献中,经常有很多的缩略词,如CPU代表Central Processing Unit等。为了方便学习,Qili决定从一批英文论文中提取出所有的缩略词以及它们的全称。

经过初步判断,这些文章的缩略词都是以全部大写字母的形式出现,而且每个缩略词之后会有一个空格,之后是它的全称。全称使用“()”括起来,左括号跟它后面的单词之间没有空格,右括号跟它前面的单词之间没有空格,全称的每个单词的首字母与缩略词的顺序是对应的。全称的单词之间可能有连字符“-”连接。

你来帮Qili编写这个程序,将所有的缩略词和全称提取出来。

Input

一篇英文文章,每个缩略词第一次出现时,其后都跟有它的英文全称;同样的缩略词再出现时,将不再出现全称。每个缩略词和全称都不会太长。缩略词总数小于100。

Output

如果有缩略词,第一行输出“Abbreviation ==> Full Name”。之后每个缩略词和它的全称占一行,包括缩略词的序号(从1开始)、缩略词、分隔符(==>)和全称。所有输出以分隔符(==>)分为两部分,右侧的全称左对齐,左侧的缩略词右对齐,但序号和第一行的“Abbreviation”是左对齐的。每个缩略词只输出一遍。

如果没有缩略词,则输出:There is no abbreviations in this text.

Sample Input

COMputers such as the ENIAC (Electronic Numerical Integrator And Computer) had to be physically rewired in order to perform different tasks, which caused these machines to be called "fixed-program computers."

Sample Output

Abbreviation ==> Full Name 1: ENIAC ==> Electronic Numerical Integrator And Computer

HINT

注意:大写的不一定都是缩写,有括号的不一定都是全称。可以做一个函数忽略字母的大小写判断字符相同。
提取缩略词时应注意:英文全称的单词之间不一定只用空格分开,有些英文单词是带连字符的,但是其首字母也会被提取出缩略词。
 
这道题目需要考虑的问题比较多,但选择思路不同,可能问题的复杂程度也会不同。
另外,在读题上,我也存在的很大失误,由于读题问题,导致选择的思路不合适,以至于最后改代码的越改越乱。
我总结的需要注意的问题有一下几点:
1.一定在做题之前认真分析题目,逐字逐句的读,想清楚再动手写代码,这样可以起到事半功倍的效果
2.边写边测试,在继续写程序之前务必确保之前的代码是完全正确的。
3.注意函数的使用,恰当的使用函数可以是程序结构更加清晰
4.综合考虑各种极端情况,比如最开头,最结尾,无解,一解,单字母等等情况,使用指针时尤其注意指针越界访问

以下贴一下我的代码:

  1. #include <stdio.h>
  2. #include <ctype.h>
  3. #include <string.h>
  4. char str[];
  5. void printste(char *s,char *e){
  6. while(s<=e)putchar(*s++);
  7. }
  8. int is_upper(char *s,char *e){
  9. while(s<=e)if(!isupper(*s++))return ;
  10. return ;
  11. }
  12. int match_word(char *s,char *e,char *as,char *ae){
  13. if(s>e||as>ae||*(e)==' ')return ;
  14. while(s<=e&&as<=ae){
  15. if(*as++!=toupper(*s++))return ;
  16. while(*s!=' '&&*s!='-')s++;
  17. s++;
  18. }
  19. if(s<=e)return ;
  20. return ;
  21. }
  22. void search(char * p){
  23. int cnt=;
  24. char * p0=p,*p1;
  25. while(p0!=NULL){
  26. int ok=;
  27. char *p3;//p0代表(,p1代表),p3代表缩略词首字母
  28. if((p0=strchr(p0,'('))==NULL)break;
  29. if((p1=strchr(p0+,')'))==NULL)break;
  30. p3=p0-;
  31. if(p3-p>=&&*(p3+)==' ')while(p3-p>=&&isupper(*(p3)))p3--;//防止下标越界
  32. else ok=;
  33. if(islower(*(p3))) ok=;
  34. if(ok&&match_word(p0+,p1-,++p3,p0-)){
  35. if(!cnt)printf("Abbreviation ==> Full Name\n");
  36. printf("%d:",++cnt);
  37. *(p0-)='\0';
  38. if((cnt)/==)printf("%10s",p3);
  39. else if((cnt)/==)printf("%9s",p3);
  40. *(p0-)=' ';
  41. printf(" ==> ");
  42. printste(p0+,p1-);
  43. printf("\n");
  44. }
  45. p0=p1;
  46. }
  47. if(cnt==) printf("There is no abbreviations in this text.\n");
  48. }
  49. int main(){
  50. int ch;
  51. int k=;
  52. while((ch=getchar())!=EOF)
  53. str[k++]=(ch=='\n')?' ':ch;
  54. str[k]=' ';str[k++]=' ';str[k++]=;//防止字符串末尾下标越界
  55. search(str);
  56. return ;
  57. }

SDUST作业10 Problem J: 提取缩略词的更多相关文章

  1. SDUST 作业10 Problem I 液晶显示

    Description 你的朋友刚买了一台新电脑,他以前用过的最强大的计算工具是一台袖珍计算器.现在,看着自己的新电脑,他有点失望,因为他更喜欢计算器上的LC显示器.所以,你决定写一个LC显示风格的程 ...

  2. SDUST 作业10 Problem D 魔方阵

    Description 所谓N阶魔方阵,是一个N*N的方阵,其元素由1到N^2组成,且方阵每行每列以及对角线的元素和相等.如三阶魔方阵: 8 1 6 3 5 7 4 9 2     魔方阵的规律如下: ...

  3. 在IT产品白皮书中遇到的缩略词

    在IT产品白皮书中遇到的缩略词 更新中...

  4. ldap理论属于概念缩略词

    Standalone LDAP Daemon, slapd(standalone lightweight access protocol) ldap 389 default listener port ...

  5. IT相关术语、缩略词

    CLI Command Line Interface 命令行界面 GUI Graphical User Interface 图形用户界面 IP Internet Protocol 因特网协议 JDK ...

  6. 山科SDUST OJ Problem J :连分数

    Problem J: 连分数 Time Limit: 1 Sec  Memory Limit: 64 MBSubmit: 2723  Solved: 801[Submit][Status][Web B ...

  7. 实验12:Problem J: 动物爱好者

    #define null ""是用来将字符串清空的 #define none -1是用来当不存在这种动物时,返回-1. 其实这种做法有点多余,不过好理解一些. Home Web B ...

  8. The Ninth Hunan Collegiate Programming Contest (2013) Problem J

    Problem J Joking with Fermat's Last Theorem Fermat's Last Theorem: no three positive integers a, b, ...

  9. 2010-2011 ACM-ICPC, NEERC, Moscow Subregional Contest Problem J. Joke 水题

    Problem J. Joke 题目连接: http://codeforces.com/gym/100714 Description The problem is to cut the largest ...

随机推荐

  1. C++学习41 exception类

    C++语言本身或者标准库抛出的异常都是 exception 的子类,称为标准异常(Standard Exception).你可以通过下面的语句来匹配所有标准异常: try{ //可能抛出异常的语句 } ...

  2. 创建一个struts2的HelloWorld

    1.下载struts2的jar包 http://struts.apache.org/download.cgi#struts255 下载一个稳定版本Struts 2.3.31 里面提供了maven ja ...

  3. [ActionScript 3.0] AS3.0 水面波纹效果

    import flash.geom.Point; import flash.display.BitmapData; import flash.filters.DisplacementMapFilter ...

  4. MyEclipse运行时自动保存

    今天第一次用MyEclipse,我发现我的代码明明修改了,但运行结果发现总是修改前的代码结果.后来发现,是代码修改后必须保存,再点运行.这个功能明显不合适,所以需要更改MyEclipse的配置.红框是 ...

  5. CRM 2016 自动保存 Save event arguments

    Save event arguments (client-side reference)   Applies To: Dynamics CRM 2016, Dynamics CRM Online In ...

  6. textarea文本换行和页面显示换行符

    在textarea里写的文本有换行,但是显示到页面后就不会自动换行,通过对数据分析发现textarea里的换行符是\n\r,然而HTML中的换行为<\br>解决办法有两种: 第一种:把文本 ...

  7. Visual Studio 2015正式版/产品密钥 Win10正式版官方原版ISO镜像下载大全&安装激活教程

    Visual Studio 2015  发行说明: https://visualstudio.com/zh-cn/news/vs2015-vs.aspx Visual Studio  2015 特性简 ...

  8. 算法库:clapack安装配置

    类似于opencv.jpeglib和pnglib的安装配置. opencv安装配置见:http://www.cnblogs.com/dzyBK/p/4954945.html jpeglib和pngli ...

  9. c++cin.ignore()

    c++ 中cin.ignore(100,'\n'); 的作用是清除输入流中多余的字符请问这句话是什么意思? 可以举个例子吗? 提问者采纳 这个其实就是忽略cin中的前100个字符,或是'\n'之前的字 ...

  10. 在weblogic11g上发布项目遇到的一个错误(不支持web-app_3_0)

    错误信息如下: 消息图标 - 错误 [HTTP:101064][WebAppModule(ssh1:ssh1.war)] Error parsing descriptor in Web appplic ...