• POJ 3371 Flesch Reading Ease (模拟题)


    Flesch Reading Ease

    题目很水,就是看懂题就行。

    题意:

      给出一篇规范的文章,求其 句子数、单词数 和 音节数把这3个值代入题目给出的公式,输出其结果,保留2位小数。  

      标记单词分隔符: 逗号(,) 和 空格( )

      句子分隔符:句号(.) 问号(?) 冒号(:) 分号(;) 感叹号(!)

      音节处理要求:

      (1)当单词总长度<=3时,音节数无条件+1

      (2) 当单词总长度>3时,单词中每出现一个元音字母(a、e、i、o、u、y),音节数+1,但是连续的(>=2)元音字母只按1个音节计算,且当单词后缀为-es、-ed和-e时,后缀的元  音字母e不列为音节数计算。但是后缀-le例外,要计算音节数。

    思路:没什么好说的,模拟水题,不知道为什么没人做0.0

     1 #include <stdio.h>
     2 #include <string.h>
     3 
     4 bool is_yuan(char c)
     5 {
     6     if(c == 'a' || c == 'e' || c == 'i' || c == 'o' || c == 'u' || c == 'y')
     7         return true;
     8     if(c == 'A' || c == 'E' || c == 'I' || c == 'O' || c == 'U' || c == 'Y')
     9         return true;
    10     return false;
    11 }
    12 
    13 int main()
    14 {
    15     char s[1010];
    16     int sentences = 0, words = 0, syllables = 0;
    17     while(~scanf("%s", s))
    18     {
    19         bool qian = false;
    20         int len = strlen(s);
    21         if(len <= 3)
    22         {
    23             syllables++;
    24             //printf("1 ");
    25         }
    26         else
    27         {
    28             if(is_yuan(s[0]))
    29             {
    30                 syllables++;
    31                 qian = true;
    32                 //printf("%d ", 0);
    33             }
    34             for(int i = 1; i < len; i++)
    35             {
    36                 if(is_yuan(s[i]) && !qian)
    37                 {
    38                     syllables++;
    39                     qian = true;
    40                    // printf("%d ", i);
    41                 }
    42                 else if(!is_yuan(s[i]))
    43                 {
    44                     qian = false;
    45                 }
    46             }
    47             if(s[len-1] == ',' || s[len-1] == '.' || s[len-1] == ';' || s[len-1] == '!' || s[len-1] == '?' || s[len-1] == ':')
    48             {
    49                 if((s[len-2] == 'e' && s[len-3] != 'l' && !is_yuan(s[len-3])) || (s[len-2] == 's' && s[len-3] == 'e' && !is_yuan(s[len-4])) || (s[len-2] == 'd' && s[len-3] == 'e' && !is_yuan(s[len-4])))
    50                 {
    51                     syllables--;
    52                     //printf("*");
    53                 }
    54             }
    55             else
    56             {
    57                 if((s[len-1] == 'e' && s[len-2] != 'l' && !is_yuan(s[len-2])) || (s[len-1] == 's' && s[len-2] == 'e' && !is_yuan(s[len-3])) || (s[len-1] == 'd' && s[len-2] == 'e' && !is_yuan(s[len-3])))
    58                 {
    59                     syllables--;
    60                     //printf("#");
    61                 }
    62             }
    63         }
    64         if(s[len-1] == '.' || s[len-1] == ';' || s[len-1] == '!' || s[len-1] == '?' || s[len-1] == ':')
    65         {
    66             sentences++;
    67         }
    68         words++;
    69         //puts("");
    70     }
    71     //printf("%d %d %d
    ", syllables, words, sentences);
    72     printf("%.2f
    ", 206.835-1.015*words/sentences-84.6*syllables/words);
    73 
    74     return 0;
    75 }
    Flesch Reading Ease
  • 相关阅读:
    关于JDK中的设计模式
    关于Java中的构造方法和set方法()给属性赋值
    关于Object[]数组强转成Integer[]类型的数组.
    [ImportNew]Java中的Timer类和TimerTask类
    关于Linux最基本总结
    关于数组
    关于Linux系统和Windows系统中文件夹的命名规范
    关于数组集合之间的转换
    关于Java获取系统信息
    关于Windows常用命令
  • 原文地址:https://www.cnblogs.com/Silence-AC/p/3545783.html
Copyright © 2020-2023  润新知