• String的几个面试题


    1.. 第一个只出现一次的字符

    1. class Solution {
    2. public int firstUniqChar(String s) {
    3. int []count =new int[125];
    4. for(int i=0;i
    5. char ch=s.charAt(i);
    6. count[ch]++;
    7. }
    8. for(int i=0;i
    9. char ch = s.charAt(i);
    10. if (count[ch] == 1) {
    11. return i;
    12. }
    13. }
    14. return -1;
    15. }
    16. }

    假设是这样一组字符串,返回第一个只出现一次的字符,那就是b,我们可以这样做

    1.创建一个大的数组,用来记录每个字母出现的次数

    2.再次遍历字符串,返回计数数组是1的字母的下标; 

    但是这样浪费的空间比较多,所以采取-97的做法,正好对应0,1,2,3等这样的位置

    1. class Solution {
    2. public int firstUniqChar(String s) {
    3. int []count =new int[125];
    4. for(int i=0;i
    5. char ch=s.charAt(i);
    6. count[ch-97]++;
    7. }
    8. for(int i=0;i
    9. char ch = s.charAt(i);
    10. if (count[ch-97] == 1) {
    11. return i;
    12. }
    13. }
    14. return -1;
    15. }
    16. }

    2.求最后一个单词的长度

    1. import java.util.Scanner;
    2. // 注意类名必须为 Main, 不要有任何 package xxx 信息
    3. public class Main {
    4. public static void main(String[] args) {
    5. Scanner in = new Scanner(System.in);
    6. // 注意 hasNext 和 hasNextLine 的区别
    7. while (in.hasNextLine()) { // 注意 while 处理多个 case
    8. String str=in.nextLine();
    9. int index=str.lastIndexOf(" ");
    10. String ret=str.substring(index+1);
    11. int l=ret.length();
    12. System.out.println(l);
    13. }
    14. }
    15. }

    这道题就用了String的库函数

    3.判断是否为回文串

    1. class Solution {
    2. public boolean isPalindrome(String s) {
    3. s.toLowerCase();
    4. int left=0;
    5. int right=s.length()-1;
    6. while(left
    7. while(left
    8. left++;
    9. }
    10. while(left
    11. right--;
    12. }
    13. if(s.charAt(left)!=s.charAt(right)){
    14. return false;
    15. }else{
    16. left++;
    17. right--;
    18. }
    19. }
    20. return true;
    21. }
    22. private boolean isValidChar(char ch){
    23. if(Character.isDigit(ch)||Character.isLetter(ch)){
    24. return true;
    25. }
    26. return false;
    27. }
    28. }

    这个题面试中常考,回文串就是正着写和倒着写是一样的,方法是这样的

    先将所有字母变成小写,再看看是否符合数字或者字母,符合得话,左边往后走,右边往前走

    然后判断左边和右边的是否相等,如果不相等,就返回FALSE,如果相等,就继续走

    在判断字符是否合法时,可以使用char的包装类的方法进行判断

  • 相关阅读:
    如何将「知识」体系化管理
    要写论文了,怎么搞?
    拥抱数字正义时代,看AIGC如何驱动法律变革
    将来进行时习题
    Redis(四)持久化策略
    【运维】docker如何删除所有容器
    MySql出错点
    开源无人机如何实现空对地框选撞击?
    [计算机毕业设计]知识图谱的检索式对话系统
    java计算机毕业设计高校社团管理系统MyBatis+系统+LW文档+源码+调试部署
  • 原文地址:https://blog.csdn.net/weixin_61436104/article/details/128096687