JAVA代码—算法基础:键盘行字符处理问题

键盘行字符处理问题

问题链接:https://leetcode.com/problems/keyboard-row/description/

问题描述

给定一个单词列表,判断其中哪些单词所包含的字符可以使用下面图例中的键盘上的同一行字母就可以构成。
输出这样的单词。

这里写图片描述

注意:假设键盘上同一行的字符可以多次使用。
输入的单词列表中所包含的字符仅仅是字母构成。

算法设计

package com.bean.algorithmbasic;

import java.util.HashMap;
import java.util.LinkedList;
import java.util.List;
import java.util.Map;

public class KeyboardRow {

    public static String[] findWords(String[] words) {
        //把键盘上的每一行字母作为一个字符串数组的元素表示出来。(只处理26个字母)
        String[] strs = {"QWERTYUIOP","ASDFGHJKL","ZXCVBNM"};
        //创建一个map对象
        Map<Character, Integer> map = new HashMap<>();
        //将字符串数组元素转化为字符数组,然后依次装入map对象中。
        //map对象的KEY对应字符,VALUE对应行标(rowIndex)
        for(int i = 0; i<strs.length; i++){
            for(char c: strs[i].toCharArray()){
                map.put(c, i);//put <char, rowIndex> pair into the map
            }
        }
        List<String> res = new LinkedList<>();
        for(String w: words){
            if(w.equals("")) continue;
            int index = map.get(w.toUpperCase().charAt(0));
            for(char c: w.toUpperCase().toCharArray()){
                if(map.get(c)!=index){
                    index = -1; //don't need a boolean flag. 
                    break;
                }
            }
            if(index!=-1) res.add(w);//if index != -1, this is a valid string
        }
        return res.toArray(new String[0]);
    }

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        String[] array= {"Hello", "Alaska", "Dad", "Peace"};
        String[] result=findWords(array);
        for(int i=0;i<result.length;i++) {
            System.out.println(result[i]);
        }

    }

}

输出结果:

Alaska
Dad

(完)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值