Comment puis-je vérifier si un seul personnage apparaît dans une chaîne de caractères?

en Java est-il un moyen de vérifier la condition:

"est-ce le seul personnage apparaît dans la chaîne de x"

sans utilisant une boucle?

153
demandé sur ArjunShankar 2009-02-03 08:38:42

15 réponses

vous pouvez utiliser string.indexOf('a') .

si le 'a' est présent dans string , il renvoie l'indice(>=0). Si non, il retourne -1. Ainsi, une valeur de retour non négative signifie que 'a' is present in the string .

208
répondu mP. 2015-11-03 22:27:34
  • String.contains() qui vérifie si la chaîne contient une séquence spécifiée de valeurs de char
  • String.indexOf() qui renvoie l'index dans la chaîne de la première occurrence du caractère spécifié ou du substrat (il y a 4 variations de cette méthode)
128
répondu Zach Scrivena 2009-02-03 06:56:00

Je ne suis pas sûr de ce que l'affiche originale demande exactement. Depuis indexOf(...) et contient des(...) les deux probablement utilisent des boucles internes, peut-être cherche-t-il à voir si cela est possible sans boucle? Je peux penser à deux façons hors de la portée de la main, l'un serait bien sûr récidive:

public boolean containsChar(String s, char search) {
    if (s.length() == 0)
        return false;
    else
        return s.charAt(0) == search || containsChar(s.substring(1), search);
}

l'autre est beaucoup moins élégant, mais complet...:

/**
 * Works for strings of up to 5 characters
 */
public boolean containsChar(String s, char search) {
    if (s.length() > 5) throw IllegalArgumentException();

    try {
        if (s.charAt(0) == search) return true;
        if (s.charAt(1) == search) return true;
        if (s.charAt(2) == search) return true;
        if (s.charAt(3) == search) return true;
        if (s.charAt(4) == search) return true;
    } catch (IndexOutOfBoundsException e) {
        // this should never happen...
        return false;
    }
    return false;
}

le nombre de lignes augmente comme vous avez besoin de soutenir de plus en plus longues chaînes de cours. Mais il n'y a aucune boucle/récidive du tout. Vous pouvez même supprimer la vérification de longueur si vous craignez que cette longueur() utilise une boucle.

28
répondu Jack Leow 2009-02-03 13:53:56
String temp = "abcdefghi";
if(temp.indexOf("b")!=-1)
{
   System.out.println("there is 'b' in temp string");
}
else
{
   System.out.println("there is no 'b' in temp string");
}
12
répondu Richard 2011-07-11 07:00:51

Pour vérifier si quelque chose n'existe pas dans une chaîne, vous devez au moins rechercher à chaque caractère dans une chaîne. Donc même si vous n'utilisez pas explicitement une boucle, elle aura la même efficacité. Cela étant dit, vous pouvez essayer d'utiliser str.contient(""+char).

3
répondu mweiss 2009-02-03 05:41:44

Si vous avez besoin de vérifier la même chaîne, souvent, vous pouvez calculer le personnage occurrences. C'est une implémentation qui utilise un tableau de bits contenu dans un tableau long:

public class FastCharacterInStringChecker implements Serializable {
private static final long serialVersionUID = 1L;

private final long[] l = new long[1024]; // 65536 / 64 = 1024

public FastCharacterInStringChecker(final String string) {
    for (final char c: string.toCharArray()) {
        final int index = c >> 6;
        final int value = c - (index << 6);
        l[index] |= 1L << value;
    }
}

public boolean contains(final char c) {
    final int index = c >> 6; // c / 64
    final int value = c - (index << 6); // c - (index * 64)
    return (l[index] & (1L << value)) != 0;
}}
3
répondu fillumina 2012-05-07 11:16:01

Oui, à l'aide de la méthode indexOf() sur la classe string. voir la documentation API pour cette méthode

2
répondu Mystic 2009-02-03 05:44:38
package com;
public class _index {

    public static void main(String[] args) {
        String s1="be proud to be an indian";
        char ch=s1.charAt(s1.indexOf('e'));
        int count = 0; 
        for(int i=0;i<s1.length();i++) {
            if(s1.charAt(i)=='e'){
                System.out.println("number of E:=="+ch);
                count++;
            }
        }
        System.out.println("Total count of E:=="+count);
    }
}
1
répondu Praveen kumar 2013-11-27 04:40:43

vous pouvez utiliser 2 méthodes de la classe String .

  • String.contains() qui vérifie si la chaîne contient une séquence spécifiée de valeurs de char
  • String.indexOf() qui renvoie l'index dans la chaîne de la première occurrence du caractère spécifié ou substring ou renvoie -1 si le caractère n'est pas trouvé (il y a 4 variantes de cette méthode)

Méthode 1:

String myString = "foobar";
if (myString.contains("x") {
    // Do something.
}

Méthode 2:

String myString = "foobar";
if (myString.indexOf("x") >= 0 {
    // Do something.
}

Links by: Zach Scrivena

1
répondu Halfacht 2018-03-27 13:14:16
String s="praveen";
boolean p=s.contains("s");
if(p)
    System.out.println("string contains the char 's'");
else
    System.out.println("string does not contains the char 's'");

sortie

string does not contains the char 's'
0
répondu praveen 2011-10-05 07:27:00
static String removeOccurences(String a, String b)
{
    StringBuilder s2 = new StringBuilder(a);

    for(int i=0;i<b.length();i++){
        char ch = b.charAt(i);  
        System.out.println(ch+"  first index"+a.indexOf(ch));

        int lastind = a.lastIndexOf(ch);

    for(int k=new String(s2).indexOf(ch);k > 0;k=new String(s2).indexOf(ch)){
            if(s2.charAt(k) == ch){
                s2.deleteCharAt(k);
        System.out.println("val of s2 :             "+s2.toString());
            }
        }
      }

    System.out.println(s1.toString());

    return (s1.toString());
}
0
répondu Ganeshmani 2012-05-22 05:21:00
you can use this code. It will check the char is present or not. If it is present then the return value is >= 0 otherwise it's -1. Here I am printing alphabets that is not present in the input.

import java.util.Scanner;

public class Test {

public static void letters()
{
    System.out.println("Enter input char");
    Scanner sc = new Scanner(System.in);
    String input = sc.next();
    System.out.println("Output : ");
    for (char alphabet = 'A'; alphabet <= 'Z'; alphabet++) {
            if(input.toUpperCase().indexOf(alphabet) < 0) 
                System.out.print(alphabet + " ");
    }
}
public static void main(String[] args) {
    letters();
}

}

//Ouput Example
Enter input char
nandu
Output : 
B C E F G H I J K L M O P Q R S T V W X Y Z
0
répondu Nandu cg 2018-01-09 06:05:34

, c'est ce que vous cherchiez?

int index = string.indexOf(character);
return index != -1 && string.lastIndexOf(character) != index;
0
répondu Toochka 2018-03-27 13:20:16

j'ai utilisé la ficelle.comprend() méthode qui retourne true ou false si la chaîne ou le caractère est trouvé. Voir ci-dessous la documentation.

https://www.w3schools.com/jsref/jsref_includes.asp

-1
répondu Udugam 2018-03-28 02:37:30

//ce n'est le principal... vous pouvez utiliser un lecteur tamponné ou un scanner

string s;
int l=s.length();
int f=0;
for(int i=0;i<l;i++)
   {
      char ch1=s.charAt(i); 
      for(int j=0;j<l;j++)
         {
          char ch2=charAt(j);
          if(ch1==ch2)
           {
             f=f+1;
             s.replace(ch2,'');
           }
          f=0;
          }
     }
//if replacing with null does not work then make it space by using ' ' and add a if condition on top.. checking if its space if not then only perform the inner loop... 
-4
répondu anytime 2012-01-11 03:49:13