题目描述
编写一个函数,以字符串作为输入,反转该字符串中的元音字母。
方法
双指针
使用双指针,一个指针从头向尾遍历,一个指针从尾巴到头遍历,当两个指针都遍历到元音字符时,交换。
为了快速判断一个字符是不是元音字符,将全部元音字符添加到集合HashSet中。
代码
自己需要补充的地方
- String类型的 contains() 方法,判断字符串是否有子字符串。
- final 关键字
- 修饰类
表示这个类不能被继承。final类中的成员变量可以根据需要设为final,但是要注意final类中的所有成员方法都会被隐式地指定为final方法。 - 修饰方法
只有在想明确禁 该方法在子类中被覆盖的情况下才将方法设置为final的。 - 修饰变量
对于一个final变量,如果是基本数据类型的变量,则其数值一旦在初始化之后便不能更改;如果是引用类型的变量,则在对其初始化之后便不能再让其指向另一个对象。
- 修饰类
- static 关键字
- 修饰成员变量和成员方法。静态变量、静态方法,独立于该类的任何对象,可以通过类名来访问。
- 用 public 修饰的 static 成员变量和成员方法本质是全局变量和全局方法,当声明它类的对象时,不生成 static 变量的副本,而是类的所有实例共享同一个 static 变量。
- private 修饰的 static 变量,表示这个变量可以在类的静态代码块中,或者类的其他静态成员方法中使用(当然也可以在非静态成员方法中使用),但是不能在其他类中通过类名来直接引用。
- private 时访问权限限定, static 表示不要实例化就可以使用。
- static 和 final 一起使用,修饰成员变量和成员方法,可简单理解为“全局常量”。
- 对于变量,表示一旦给值就不可修改,并且通过类名可以访问。
- 对于方法,表示不可覆盖,并且可以通过类名直接访问。
- 注意:
对于 被 static 和 final 修饰过的实例变量,实例本身不能再改变了,但对于一些容器类型(比如ArrayList、HashMap)的实例变量,不可以改变容器变量本身,但可以修改容器中存放的对象。
- Arrays.asList() 方法
** 该方法时将数组转化为List集合的方法。**
List<String> list = Arrays.asList("a", "b", "c");
- 该方法适用于对象型数据的数组(String、Integer…)
- 该方法不建议使用于基本数据类型的数组(byte,short,int,long,float,double,boolean)
- 方法将数组与List列表链接起来:当更新其一个时,另一个自动更新
- 不支持add()、remove()、clear()等方法
- 用此方法得到的 list 长度不可改变
- 如果只是用来遍历,可以使用Arrays.asList().
- 如果你的 list 还要添加或删除元素,那就 new 一个 java.util.ArrayList,然后一个一个添加元素。
- i++:先进性表达式运算,再进行自增运算。
还需要再研究的地方
private final static HashSet<Character> vowels = new HashSet<> (
Arrays.asList('a', 'e', 'i', 'o', 'u', 'A', 'E', 'I', 'O', 'U'));