比如abcdefgabdef

其中字符c和g不重复,返回c的小标,下标从0开始,那么是2

package com.example.demo;

import org.testng.annotations.Test;

import java.util.ArrayList;
import java.util.LinkedHashSet; public class Test111 { String str1 = "abcdefgabdef"; @Test
public void fun1(){
//LinkedHashSet 有序的set集合
LinkedHashSet<Character> once = new LinkedHashSet<>();
LinkedHashSet<Character> chongFu = new LinkedHashSet<>();
ArrayList<Character> list = new ArrayList<>(); for (int i = 0; i < str1.length(); i++) {
boolean add = once.add(str1.charAt(i)); // 得到集合里所有出现过一次的元素 if (!add) {
chongFu.add(str1.charAt(i));// 得到集合里重复出现的元素
}
} boolean removeAll = once.removeAll(chongFu); // once里将存储所有不重复的元素
list.addAll(once);
System.out.println("所有不重复的字母:" + list);
for (int i = 0; i < str1.length(); i++) {
if (list.get(0) == str1.charAt(i)) {
System.out.println("它的索引为:" + i);
}
}
} @Test
public void fun2(){
ArrayList<Character> list = new ArrayList<>();
for (int i = 0; i < str1.length(); i++) {
int flag = -1;// 定义一个标志
for (int j = 0; j < str1.length(); j++) {
if (i == j) {// 如果是同一个元素跳过本次循环,继续下次循环
continue;
}
// 如果这个元素不是第一次出现,将标志改变
if (str1.charAt(i) == str1.charAt(j)) {
flag = 1;
}
}
// 未改变标志的元素,即只出现一次的元素
if (flag == -1) {
list.add(str1.charAt(i));
} // if } // for
System.out.println("所有不重复的字母:" + list);
System.out.println("第一个不重复的字母为:" + list.get(0));
for (int i = 0; i < str1.length(); i++) {
if (list.get(0) == str1.charAt(i)) {
System.out.println("它的索引为:" + i);
}
}
} @Test
public void fun3(){
for (int i = 0; i < str1.length(); i++) {
char charAt = str1.charAt(i);
// 找出取出的元素第一次出现的位置
int indexOf = str1.indexOf(charAt);
// 找出取出的元素最后一次出现的位置
int lastIndexOf = str1.lastIndexOf(charAt);
// 如果是唯一的元素,第一次出现的位置和最后一次出现的位置应该相同
// 如果相同了就没必要在继续走for循环了
if (indexOf == lastIndexOf) {
System.out.println(str1.charAt(indexOf));
System.out.println(indexOf);
return;
}
}
}
}

BF算法
BF算法,即Brute Force 算法的简称。用于检测某个字符串是否是另一个字符串的子串。

子串的概念#
假设字符串 X = 'girlfriend' , Y = 'friend' ,那么Y 就是 X的子串。同样的,end是friend的子串。

BF算法的思路#
BF算法的思路非常简单粗暴,就是从前到后一点点的匹配。例如: 子串 x= abcd | 主串为 y = abdabceabcde
如果 x[0] = y[0] 继续比较 x[1] y[1] 继续下去,如果一直到 x[3]= y[3]时 则 x 整个串都匹配上了。
如果 x[0] = y[0] 继续比较 x[1] y[i] 发现不等,那么就开始用 x[0] 比较 y[1] 然后继续 x[1] y[2]。

public class TestBF {

    public static void main(String[] args) {
System.out.println(isSubstring("abdabceabcde","abcd")); // true
System.out.println(isSubstring("abdabceabcde","ff")); // false
} private static boolean isSubstring(String main,String sub){
if(main == null || sub == null) {
return false;
}
if(main.length() < sub.length()) { // 子串不可比主串长
return false;
}
if(main.equals(sub)) { // 主串,子串 相等的情况
return true;
}
int len = main.length() - sub.length();
for (int i = 0; i < len; i++) {
boolean match = true;
for (int j = 0; j < sub.length(); j++) {
if(main.charAt(i+j) != sub.charAt(j)) {
match = false;
break;
}
}
if(match) {
return true;
}
}
return false;
} }

  

  

Java 返回字符串中第一个不重复字符的下标 下标从0开始的更多相关文章

  1. 找出字符串中第一个不重复的字符(JavaScript实现)

    如题~ 此算法仅供参考,小菜基本不懂高深的算法,只能用最朴实的思想去表达. //找出字符串中第一个不重复的字符 // firstUniqueChar("vdctdvc"); --& ...

  2. Java求字符串中出现次数最多的字符

    Java求字符串中出现次数最多的字符  [尊重原创,转载请注明出处]http://blog.csdn.net/guyuealian/article/details/51933611      Java ...

  3. 使用 Java 查找字符串中出现次数最多的字符以及出现的次数?

    使用 Java 查找字符串中出现次数最多的字符以及出现的次数? import java.util.HashMap; import java.util.Map; public class TestStr ...

  4. java截取字符串中的最后几个字符

    Java中的String类提供了一个substring(int from, int to)方法用于截取字符串中位置为from到to-1位置的字符. 因为字符串的字符位置是从0开始的,而substrin ...

  5. leetCode 题解之字符串中第一个不重复出现的字符

    1.题目描述 Given a string, find the first non-repeating character in it and return it's index. If it doe ...

  6. java一个字符串中出现次数最多的字符以及次数

    学习了别人的方法,觉得挺巧妙的.就是每次取出字符串的第一个字符,将字符串中与第一个字符相同的字符全部删除掉,然后通过计算删除前后字符串的长度来确定该字符在字符串中出现的次数,最终比较出出现最多次的字符 ...

  7. 三种java 去掉字符串中的重复字符函数

    三种java 去掉字符串中的重复字符函数 public static void main(string[] args) { system.out.println(removerepeatedchar( ...

  8. 剑指Offer-字符流中第一个不重复的字符

    package String; import java.util.LinkedHashMap; import java.util.Map; /** * 字符流中第一个不重复的字符 * 题目描述 * 请 ...

  9. H面试程序(12): 输出字符串中第一个只出现一次的字母

    题目描述: 若字符串str为'' sbdddsbfc'',则输出 f; 若字符串str为''aabbccdd'',则输出:字符串str中的字符都出现两次以上 #include <stdio.h& ...

随机推荐

  1. SDKMAN一个基于命令行界面的SDK用户环境管理程序

    1.背景 使用过Python开发的朋友,应该了解到Python2和Python3语法的差异,有时候从网上下载了基于不同解释器的代码,要来回切换版本, 使用起来不是很方便,有时候甚至很麻烦.于是有人发明 ...

  2. linux 下mysql 关闭 启动

    一. 启动 .使用 service 启动:service mysql start .使用 mysqld 脚本启动:/etc/init.d/mysql start .使用 safe_mysqld 启动: ...

  3. 修改IP地址之后认证信息问题

    $ ssh lvph@172.16.20.20 @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@ @ WARNING: REMOT ...

  4. OI总结

    当下考的钟声叮当响起,该走了,一年半的OI竞赛就此结束 留下了很多遗憾.也拥有过一段美好的竞赛生活 结识了一群优秀的OI战友,一起进步一起开心一起忧愁,但这一切的一切都将在今晚变成过去式,CSp的好与 ...

  5. Spring 通过@Import实现Bean的注册

    今天看到一个神奇的用法, Spring可以通过@Import导入实现了ImportBeanDefinitionRegistrar接口的类来注册那个类. ImportBeanDefinitionRegi ...

  6. 【数据结构】7.java源码关于LinkedList

    关于LinkedList的源码关注点 1.从底层数据结构,扩容策略2.LinkedList的增删改查3.特殊处理重点关注4.遍历的速度,随机访问和iterator访问效率对比 1.从底层数据结构,扩容 ...

  7. 四则运算自动出题之javaweb版

    四则运算出题机之JAVAWEB版 要求还是和之前的出题形式一样 begin.jpg <%@ page language="java" contentType="te ...

  8. C# Datatable、DataReader等转化json

    //对象转换为Json字符串 public static string ToJson(object jsonObject) { object objectValue = string.Empty; s ...

  9. java之spring mvc之Restful风格开发及相关的配置

    1. Restful : 表征状态状态转移. 传统 : url : http://localhost:8080/usersys/delete.do?user.id=12 Restful 风格:url ...

  10. loj#10012\poj2018 Best Cow Fences(二分)

    题目 #10012 「一本通 1.2 例 2」Best Cow Fences 解析 有序列\(\{a_i\}\),设\([l,r]\)上的平均值为\(\bar{x}\),有\(\sum_{i=l}^r ...