牛客网【查找兄弟单词】Java

题目描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

输入描述:
先输入字典中单词的个数,再输入n个单词作为字典单词。
输入一个单词,查找其在字典中兄弟单词的个数
再输入数字n

输出描述:
根据输入,输出查找到的兄弟单词的个数

示例
输入

3 abc bca cab abc 1
1
输出

2
bca
题目分析
结果要进行判断,有还是没有兄弟单词,没有就不输出!结果是2行数据

现在,我们来分析一下,首先,题目要求输入 3 abc bca cab abc 1 ,其中3表示后边会跟着输入 3 个单词,而这3个单词需要存进字典。也就是 abc bca cab 这 3 个单词。

紧接着第 4 个单词 abc,是第二阶段了。这个单词表示是要查找的单词。需要从 字典排序后的兄弟单词列表查找。最后的那个数字,是兄弟单词列表的一个序号,你可以理解为 List 的下标 + 1(因为List 的下标从0开始,而这个数字从 1 开始)。
————————————————

import java.util.*;
public class Main{
    public static void main(String[] args){
        Scanner sc = new Scanner(System.in);
        while(sc.hasNext()){
            int n = sc.nextInt();
            String[] str = new String[n];
            String[] xd = new String[n+1];
            for(int i = 0;i<n;i++){
                str[i] = sc.next();
            }
            Arrays.sort(str);
            String s = sc.next();
            int x = sc.nextInt();
            int count =0,k=1;
            boolean ist = false;
            for(int i = 0;i<n;i++){
                if(!s.equals(str[i])){
                    ist = isxiongdi(s,str[i]);
                    if(ist){
                        count++;
                        xd[k++]=str[i];
                    }
                }
            }
            System.out.println(count);
            if(count >= x){//判断x是否越界,我开始没有判断只有40%通过率
                System.out.println(xd[x]);
            }
        }
    }
    public static boolean isxiongdi(String str1,String str2){
        if (str1.length()!=str2.length()){
            return false;
        }
        char[] chars1 = str1.toCharArray();
        char[] chars2 = str2.toCharArray();

        Arrays.sort(chars1);
        Arrays.sort(chars2);

        return new String(chars1).equals(new String(chars2)) && !str1.equals(str2);
    }
}
  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值