题解 | #HJ059 找出字符串中第一个只出现一次的字符#

找出字符串中第一个只出现一次的字符

http://www.nowcoder.com/practice/e896d0f82f1246a3aa7b232ce38029d4

import java.util.Scanner;

/**
 * HJ59 找出字符串中第一个只出现一次的字符 - 中等
 */
public class HJ059 {

    // 从后往前遍历找最后一次
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        while (sc.hasNext()) {
            String str = sc.nextLine();
            print(str);
        }
        sc.close();
    }

    private static void print(String str) {
        // 通过数组保存字符出现的次数
        int[] timesArr = new int[26];
        for (int i = 0; i < str.length(); i++) {
            char ch = str.charAt(i);
            int index = ch - 'a';
            timesArr[index]++;
        }
        // 利用str的字符到timesArr中查找,找出值为1的char
        char ans = ' ';
        for (int i = 0; i < str.length(); i++) {
            char ch = str.charAt(i);
            int index = ch - 'a';
            if (timesArr[index] == 1) {
                ans = ch;
                break;
            }
        }
        // 结果输出
        if (ans != ' ') {
            System.out.println(ans);
        } else {
            System.out.println(-1);
        }
    }
}
全部评论

相关推荐

做人要有梦想dji:最新工位查看图片
点赞 评论 收藏
分享
2024-12-25 09:09
四川师范大学 运营
想和你交朋友的潜伏者要冲国企:先去沃尔玛亲身感受标准化流程体系,一两年后再跳槽国内任何零售行业,可以有更大选择权吧?
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务