2020827雷霆技术类笔试A

在这里插入图片描述

暴力法

思路:
遍历str,新建两个list,把所有 匹配c1 的下标放在 list1 里,把所有匹配c1的下标放在 list2 里,
不可能list1的最大值小于list2的最小值且list2的最大值小于list1的最小值的。

import java.util.ArrayList;

import java.util.Scanner;

public class test{
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String strs = sc.nextLine();
        String[] str_arr = strs.split(" ");
        String str  = str_arr[0].toLowerCase();
        String c1  =  str_arr[1].toLowerCase();
        String c2  =  str_arr[2].toLowerCase();
        ArrayList<Integer > c1_arr = new ArrayList();
        ArrayList<Integer> c2_arr = new ArrayList();

        for(int i = 0;i<str.length();i++ ){
            String c = String.valueOf(str.charAt(i));
            if(c.equals(c1) ){
                c1_arr.add(i);
            }
            if(c.equals(c2)){
                c2_arr.add(i);
            }
        }
        if(c1_arr.size()==0 ||c2_arr.size()==0){
            System.out.println(-1);
        }else {
            int res = Math.max(Math.abs(c1_arr.get(0)-c2_arr.get(c2_arr.size()-1)),Math.abs(c1_arr.get(c1_arr.size()-1)-c2_arr.get(0)));
            System.out.println(res);
        }
    }
}

或者通过Collections方法

import java.util.ArrayList;

import java.util.Collections;
import java.util.List;
import java.util.Scanner;

public class Main{
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        String strs = sc.nextLine();
        String str  = strs.split(" ")[0].toLowerCase();
        String c1  =  strs.split(" ")[1].toLowerCase();
        String c2  = strs.split(" ")[2].toLowerCase();
        List<Integer > c1_arr = new ArrayList();
        List<Integer> c2_arr = new ArrayList();


        for(int i = 0;i<str.length();i++ ){
            if(str.charAt(i) == c1.charAt(0)){
                c1_arr.add(i);
            }
            if(str.charAt(i) == c2.charAt(0)){
                c2_arr.add(i);
            }
        }

        if(c1_arr.size()==0 ||c2_arr.size()==0){
            System.out.println(-1);
        }else {
            Integer max_1 = Collections.max(c1_arr);
            Integer max_2 = Collections.max(c2_arr);
            Integer min_1 = Collections.min(c1_arr);
            Integer min_2 = Collections.min(c2_arr);
            System.out.println(Math.max(max_1-min_2,max_2-min_1));
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值