java中找出字符串第一个字符,在一个字符串中找到第一个只出现一次的字符(java实现)...

题目:在一个字符串中找到第一个只出现一次的字符。如输入abaccdeff,则输出b。

分析:这道题是2006 年google 的一道笔试题。

时间换空间,类似前面时间CSDN讨论的一道华为的面试题:在O(n)时间内,得出一个字符串每一个字符出现的次数类似;

用到这道题,可以不只是统计只出现一次的;还可以统计多次出现的

public class s17 {

public static char firstOne(String s)

{

char result = '0';

char temp;

int[] num = new int[52];

for (int i = 0; i < s.length(); i ++)

{

temp = s.charAt(i);

if ( temp >= 'a' && temp <= 'z' )

{

num[temp - 'a']++;

}

else

if (temp >= 'A' && temp <= 'Z')

{

num[temp - 'A' + 26] ++;

}

}

for (int i = 0; i < num.length; i ++)

{

if (num[i] == 1)

{

if (i >= 0 && i <=26)

{

result = (char)(i + 'a');

}

else

result = (char)(i - 26 + 'A');

break;

}

}

return result;

}

/**

* @param args

*/

public static void main(String[] args) {

// TODO Auto-generated method stub

//String s = "xabb";

String s = "abaccdeff";

//

char c = firstOne(s);

System.out.println(c);

}

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值