试题 H: 人物相关性分析 第十届蓝桥杯

试题 H: 人物相关性分析 第十届蓝桥杯

试题 H: 人物相关性分析
时间限制: 1.0s 内存限制: 512.0MB 本题总分: 20
【问题描述】
小明正在分析一本小说中的人物相关性。他想知道在小说中 Alice Bob有多少次同时出现。
更准确的说,小明定义 Alice Bob“同时出现”的意思是:在小说文本中 Alice Bob 之间不超过 K 个字符。
例如以下文本:
This is a story about Alice and Bob. Alice wants to send a private message to Bob.
假设 K = 20,则 Alice Bob 同时出现了 2 次,分别是”Alice and Bob””Bob. Alice”。前者 Alice Bob 之间有 5 个字符,后者有 2 个字符。
注意:
1. Alice Bob 是大小写敏感的, alice bob 等并不计算在内。
2. Alice Bob 应为单独的单词,前后可以有标点符号和空格,但是不能有字母。例如 Bobbi 並不算出现了 Bob
【输入格式】
第一行包含一个整数 K
第二行包含一行字符串,只包含大小写字母、标点符号和空格。长度不超过 1000000
【输出格式】
输出一个整数,表示 Alice Bob 同时出现的次数。
【样例输入】
20
This is a story about Alice and Bob. Alice wants to send a private message to Bob.

【样例输出】
2
【评测用例规模与约定】
对于所有评测用例, 1 K 1000000

 

借鉴:https://blog.csdn.net/malimingwq/article/details/88953526

在Java的String类中有个用于分割字符串的方法split(String regex):String[],将此方法用于以空格.分割输入的字符串,然后枚举返回的String[],找到配对的Alice和Bob,还可以方便的统计每对组合间间隔的字符串长度。

import java.util.Scanner;

public class Main{
    
    public static void main(String[] args)  {
        Scanner reader=new Scanner(System.in);
        int res=0;    //save result
        int K=reader.nextInt();
        reader.nextLine();    //nextLine吸取回车键
        String str=reader.nextLine();
        String words[]=str.split("\\s+|\\.");    //以空格和.分割出来,注意.空格的组合存放为空字符串
        
        //    Alice------>Bob
        for(int i=0;i<words.length;i++){
            if(words[i].equals("Alice")){
                for(int j=i+1;j<words.length;j++){
                    if(words[j].equals("Bob")){
                        int sum=1;    //这里要等于1
                        for(int k=i+1;k<j;k++){
                            sum+=words[k].length()+1;
                        }
                        if(sum<=K){
                            res++;
                        }
                    }
                }
            }
        }
        
        //Bob--------->Alice
        for(int i=0;i<words.length;i++){
            if(words[i].equals("Bob")){
                for(int j=i+1;j<words.length;j++){
                    if(words[j].equals("Alice")){
                        int sum=1;    //这里要等于1
                        for(int k=i+1;k<j;k++){
                            sum+=words[k].length()+1;
                        }
                        if(sum<=K){
                            res++;
                        }
                    }
                }
            }
        }
        System.out.println(res);
    }
    
}

 

转载于:https://www.cnblogs.com/chiweiming/p/10674087.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/100995.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • java中jbpm工作流_activity工作流

    java中jbpm工作流_activity工作流中文指南,供大家下载。。

    2022年9月8日
    0
  • IIS rewrite防盗链

    IIS rewrite防盗链针对下载地址IIS的虚拟主机的url规则[ISAPI_Rewrite]#3600=1hourCacheClockRate3600RepeatLimit32#Protecthttpd.iniandhttpd.parse.errorsfiles#fromaccessingthroughHTTPRewriteRule^/httpd(?:\.ini|\.parse\.erro…

    2022年7月23日
    7
  • pycharm不会自动补全括号_pycharm代码提示

    pycharm不会自动补全括号_pycharm代码提示安装pycharm后,输入代码后,没有补全提示首先检查是否关闭了代码提示,如下图,将红框中“PowerSaveMode”前的勾去掉第二步,如果在输入某些代码时还是没有补全提醒,可能是配置好python环境则点击file->settings->projectInterpreter,如下图选择安装的python输入代码就会有提示了…

    2022年8月28日
    1
  • 数据库中存储过程语法

    数据库中存储过程语法数据库中存储过程语法本文主要总结在数据库中存储过程的语法:存储过程的创建存储过程的删除参数的使用变量的声明if条件语句语法casewhen条件语句语法循环语句语法存储过程的创建创建语法如下:@authorbyliucreateprocedurename(in[param1]type,…,out[params]type)beginsql语句1;

    2022年7月17日
    11
  • cocos3——8.实现初学者指南

    cocos3——8.实现初学者指南

    2022年1月15日
    56
  • python服务器运维步骤_python运维服务器

    python服务器运维步骤_python运维服务器好久没有写东西了.一直做服务器开发需要写一些脚本来控制服务器的启动.本来Windows自带了任务计划,但不是特别方便,还是用python写了一下.需求:在固定的时间启动服务器先看源代码:defstart_process(date):cwd=os.getcwd();globallist_threads;globaliskill;iskill=False;foriinrange(n…

    2022年7月12日
    11

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号