A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

肖鸿耀

初级黑马

  • 黑马币:1

  • 帖子:8

  • 精华:0

本帖最后由 krui 于 2012-6-15 00:06 编辑

题目:
找出一个字符串中第一个无重复的字符。
我当时的做法是这样的:
String str = "afaafdafaaaaaaaaaaafdrmnnnnabbbb";
               
                char[] w = str.toCharArray();
                for (int i = 0; i < str.length(); i++) {
                        if (w.length - str.replace(String.valueOf(w), "").length() == 1) {
                                System.out.println(w);
                                break;
                        }
                }

后面回来的时候,又找到另外一种解法,

String testStr = "afaafdafaaaaaaaaaaafdrmnnnnabbbb";
               
                for(int i=0;i<testStr.length();i++){
            String charindex = String.valueOf(testStr.charAt(i));

            //如果这个字符第一次出现的位置和最后出现的位置相等,就说明字符串中它只出现了一次
            if(testStr.indexOf(charindex) == testStr.lastIndexOf(charindex)){
                System.out.println(charindex);
                break;
            }
            
        }

各位同学不知道还有没有更好的方法,欢迎交流。

评分

参与人数 1技术分 +1 收起 理由
赵志勇 + 1 很给力!

查看全部评分

11 个回复

倒序浏览
{:soso_e179:}
回复 使用道具 举报
不清楚这些代码是网上抄下来的呐,还是确实有过这种面试经历?
回复 使用道具 举报
柯玲 发表于 2012-6-14 23:43
不清楚这些代码是网上抄下来的呐,还是确实有过这种面试经历?

腾讯成都校园招聘4月14号技术面一面面试,现场笔试,面试官一华科毕业的做客户端的眼镜男。一来就问我愿意做客户端不,我说不擅长C++。后来问了几个底层相关的,大端存储与小端存储是怎样的回答不上来
回复 使用道具 举报
我想到一种方法,效率比较低下而已,就是把第一个字母和所有的比,然后又把第二个和所有的字母比,第三个.......依此类推,当发现有一个字母没有和任何一其它的字母相等时,就退出循环并打印。代码如下:
public static void method()
{
     String str = "afaafdafaaaaaaaaaaafdrmnxyznnnabbbb";
             char[] w = str.toCharArray();
    int sign = 0;          //定义一个标记
    for(int i = 0;i<w.length;i++)
       {
                 for(int j=0;j<w.length;j++)
                {  
                           if(i==j)      //为了避免自己和自己比较
                            j++;
                        if(j<w.length)   //为了避免数组角标越界
                        {
                               if((String.valueOf(w[i])).equals(String.valueOf(w[j])))  
                             sign++;     //当有相等的时候就加一
                        }
     
               }
                if(sign==0)     //sign==0说明当前字符没有任何其它字符与它相等,而我们要的就是它。
               {
                     System.out.println(w[i]);
                      break;   //退出循环
               }
             sign=0;
       }
}

评分

参与人数 1技术分 +1 收起 理由
赵志勇 + 1 赞一个!

查看全部评分

回复 使用道具 举报
本帖最后由 武剑峰 于 2012-6-15 09:35 编辑

呵呵,我用递归实现了一下
public class findCFChar {

        /**
         * @param args
         */
        public static void main(String[] args) {
                // TODO Auto-generated method stub
                String str1="ttttfasdfhjasdf";
                System.out.println(findcf(str1));
        }
        /*
         * 查找给定字符串中第一个重复的字符
         */

        private static char findcf(String str1) {
                // TODO Auto-generated method stub
                if(str1.length()>1){                       //先判断字符串长度是否大于1
                String strcf=str1.substring(0,1);    //截取第一字符
                String strzz=str1.substring(1);      //截取第一字符之后的字符串
                if(strzz.indexOf(strcf)!=-1){           //判断第一字符是否在后边中出现过,没有就返回-1,有则将此字符返回到主方法中
                        return strcf.charAt(0);
                }else{
                        return findcf(strzz);                //将后边的字符递归继续查找
                        }
                }else {
                       System.out.print("此字符串中不存在重复字符");
                        return '0';
                         }
               
        }

}
回复 使用道具 举报
public class firstNoRepit {   
      
    public static void main(String[] args) {   
           
        String str="afaafdafaaaaaaaaaaafdrmnnnnabbbb";   
           
        System.out.println(firstNo( str));   
    }   
      
    public static Character firstNo(String str){   
           
        Map <Character,Integer> map = new HashMap<Character,Integer>();   
           
        for(int i=0; i<str.length();i++){   
               
            if(map.containsKey(str.charAt(i))){   
                  
                 map.put(str.charAt(i), 2);     
                  
            }
           else{   
                  
                 map.put(str.charAt(i), 1);   
            }   
               
               
        }   
        for(int i=0; i<str.length();i++){   
               
            if(map.get(str.charAt(i))==1 ){   
                  
                return str.charAt(i);   
            }   
        }   
           
        return null;   
    }   
  
}  
回复 使用道具 举报
本帖最后由 王明明 于 2012-6-15 10:45 编辑
  1. public class Demo
  2. {
  3.        public static void main(String args[])
  4.       {
  5.              String str="afaafdafaaaaaaaaaaafdrmnnnnabbbb";
  6.              for(int i = 0; i < str.length(); i++)
  7.             {
  8.                      if(str.lastIndexOf(str.charAt(i)) == i && str.indexOf(str.charAt(i)) == i)
  9.                     {
  10.                             System.out.println(str.charAt(i));
  11.                             break;
  12.                     }
  13.              }
  14.       }
  15. }
复制代码
跟你第二种想法一样的...
回复 使用道具 举报
我是通过list方法去做的。不知道效率如何,反正是一种方法吧。 分享


class ListDemo{
public static void main(String[] args) {
        char ch;
        int char_index = 0;
        String str = "afaafdafaaaaaaaaaaafdrmnnnnabbbb";
        List<Character> strList = new ArrayList<Character>();
        List<Character> haveList = new ArrayList<Character>();
        for(int i = 0; i < str.length(); i++){
            ch = str.charAt(i);
            char_index = strList.indexOf(ch);
            if(haveList.indexOf(ch) >= 0 && strList.indexOf(ch) >= 0){
                strList.remove(char_index);
            }else{
                haveList.add(ch);
                strList.add(ch);
            }
        }
        
        if(strList.size() != 0){
            System.out.println(strList.get(0));
        }else{
            System.out.println("不存在这样的数据");
        }
    }
}
回复 使用道具 举报
不知道用封装的方法效率高还是自己写的效率高
回复 使用道具 举报
揭耀祖 发表于 2012-6-15 00:41
我想到一种方法,效率比较低下而已,就是把第一个字母和所有的比,然后又把第二个和所有的字母比,第三个.. ...

break; 减少循环次数
回复 使用道具 举报
刚学习,表示完全看不懂
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马