• Codewars题记 :Find the missing letter


    1、题目:

    #Find the missing letter

    Write a method that takes an array of consecutive (increasing) letters as input and that returns the missing letter in the array.

    You will always get an valid array. And it will be always exactly one letter be missing. The length of the array will always be at least 2.
    The array will always contain letters in only one case.

    Example:

    ['a','b','c','d','f'] -> 'e'
    ['O','Q','R','S'] -> 'P'
    (Use the English alphabet with 26 letters!)

    Have fun coding it and please don't forget to vote and rank this kata! :-)

    I have also created other katas. Take a look if you enjoyed this kata!

    2、我的解决方案

     1 class Kata {
     2     public static char findMissingLetter(char[] array) {
     3         int nextASCLL = (int)array[0];
     4         
     5         int lostChar = 0;
     6         
     7         for (int i = 0; i < array.length; i++) {
     8             if ((int)array[i]!=nextASCLL) {
     9                 lostChar = nextASCLL;
    10                 break;
    11             }
    12             nextASCLL++;
    13         }
    14         
    15         return (char)lostChar;
    16     }
    17 }

    3、最佳解决方案

     1 public class Kata
     2 {
     3   public static char findMissingLetter(char[] array){
     4     char expectableLetter = array[0];
     5     for(char letter : array){
     6       if(letter != expectableLetter) break;
     7       expectableLetter++;
     8     }
     9     return expectableLetter;
    10   }
    11 }

    4、总结

      这个题目主要是对char的ascll进行处理。

      每次看最佳解决方案都能学习到最简单的写法。

  • 相关阅读:
    十大经典排序算法最强总结(含Java、Python码实现)
    数据库查询优化的12种方式
    开发环境、测试环境、预发布环境、生产环境的区别
    阅站无数的我,只推荐下面这些让你起飞的
    访问控制符
    继承的意义
    数组继承的意义
    java 俄罗斯方块
    类和面向对象
    随机生成数组游戏
  • 原文地址:https://www.cnblogs.com/RivenLw/p/11284965.html
Copyright © 2020-2023  润新知