SDUST作业10 Problem J: 提取缩略词

Posted Wade_

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SDUST作业10 Problem J: 提取缩略词相关的知识,希望对你有一定的参考价值。

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

 

以上是关于SDUST作业10 Problem J: 提取缩略词的主要内容,如果未能解决你的问题,请参考以下文章

SDUST 作业10 Problem I 液晶显示

山科SDUST OJ Problem J :连分数

SDUST OJ Problem G 动态的字符串排序

SDUST 软件工程2016-作业4-A 百钱买鸡问题

如何从 facebook 视频 url 中提取缩略图

poj 1776 Task Sequences