Substrings finden

Hallo, habe folgendes Problem:
Ich möchte als Eingabe in der Konsole einen String und eine Zahl. Danach rekursiv alle möglichen Teilsequenzen davon finden.

Habe folgendes überlegt:


Java:
import java.util.Scanner;
public class Teilfolgen {
 public static int num;
 public static void main(String[] args) {
  Scanner sc = new Scanner(System.in);
  System.out.println("enter a string");
  String input = sc.next();
  System.out.println("enter a non negative integer");
  num = sc.nextInt();
  if (num < 0) {
   System.out.println("incorrect input");
  }
  findeTeilfolgen(input);
 }
 public static void findeTeilfolgen(String input) {
  if (num == input.length()) {
   System.out.println(input);
  } else {   
   findeTeilfolgen(input.substring(0, input.length() - 1));
   findeTeilfolgen(input.substring(1, input.length()));
  }
 }
}

Wenn ich nun jedoch als Input "Hund" nehme mit num = 2 sollte ich ja bekommen:
hu hn hd un ud nd
Jedoch erhalte ich nur:
hu un un nd

Ich geh davon aus, dass bei den rekursiven Aufrufen bei input.substring die 2 Parameter noch falsch sind, komme jedoch nicht drauf wie ich mein Programm änderen muss um es korrekt zu bekommen.
 

Tarrew

Top Contributor
Wenn ich nun jedoch als Input "Hund" nehme mit num = 2 sollte ich ja bekommen:
hu hn hd un ud nd
Sicher, dass du Substrings finden möchtest? "hn", "hd" und "ud" sind keine Substrings von "Hund".

Kann das sein, dass du eher alle Permutationen der Buchstaben "h", "u", "n" und "d" mit der Länge 2 suchst?
Dann fehlen in der Aufzählung wiederum einige. Oder alle Potenzmengen mit 2 Buchstaben, ohne die Reihenfolge zu verändern?

Vllt. nochmal etwas genauer beschreiben, was genau das Ziel sein soll.
 
Also bei z.b. num = 2 und String "Hund" will ich:
Buchstabe 1 + Buchstabe 2
Buchstabe 1 + Buchstabe 3
Buchstabe 1 + Buchstabe 4
Buchstabe 2 + Buchstabe 3
Buchstabe 2 + Buchstabe 4
Buchstabe 3 + Buchstabe 4
 

Tarrew

Top Contributor
Java:
   findeTeilfolgen(input.substring(0, input.length() - 1));
   findeTeilfolgen(input.substring(1, input.length()));
Ich glaube mit der substring-Methode kann das allgemein nicht klappen, da du nie Teilmengen erwischen wirst, bei denen die Buchstaben nicht direkt hintereinander liegen.

Wenn man die ganze Methode etwas erweitert und in einem boolean-Array "mittrackt" welchen Buchstaben an welchem Index man schon "abgearbeitet" hat, dann könnte das so aussehen:
Java:
    public static void main(String[] args) {
        char[] arr = "Hund".toCharArray();
        teilmenge(arr, 0, new boolean[arr.length], 2);
    }

    public static void teilmenge(char[] input, int index, boolean[] covered, int num) {
        if (index == covered.length) {
            if (countBoolean(covered, true) == num) {
                for (int i = 0; i < covered.length; i++) {
                    if (covered[i]) {
                        System.out.print(input[i]);
                    }
                }
                System.out.println();
            }
        } else {
            teilmenge(input, index + 1, covered, num);
            covered[index] = true;
            teilmenge(input, index + 1, covered, num);
            covered[index] = false;
        }
    }

    private static int countBoolean(boolean[] arr, boolean b) {
        int count = 0;

        for (boolean ab : arr) {
            count += ab == b ? 1 : 0;
        }
        return count;
    }

Vllt. hat aber jemand anderes auch eine etwas elegantere Lösung ;)


Mit externen Bibliotheken (Guava) geht das auch etwas kürzer (ggf. noch Sortierung der Indizes beachten):
Java:
    public static void main(String[] args) {
        char[] arr = "Hund".toCharArray();
        int num = 2;

        Set<Set<Integer>> powerSet = Sets.powerSet(IntStream.range(0, arr.length).boxed().collect(Collectors.toSet()))
                .stream()
                .filter(s -> s.size() == num)
                .collect(Collectors.toSet());

        for (Set<Integer> subSet : powerSet) {
            for (Integer charIndex : subSet) {
                System.out.print(arr[charIndex]);
            }
            System.out.println();
        }
    }
 
Zuletzt bearbeitet:

max40

Bekanntes Mitglied
Java:
public static void main(String[] args) {
    String s = "Hund";
    int len = 2;
    work(s.toCharArray(), new char[len], 0, 0);
}

static void work(char[] data, char[] cur, int ebene, int pos) {
    for (int i = pos, len = data.length - (cur.length - ebene - 1); i < len; i++) {
        cur[ebene] = data[i];
        if (ebene + 1 < cur.length) {
            work(data, cur, ebene + 1, i + 1);
        }else {
            System.out.println(Arrays.toString(cur));
        }
    }
}
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Fehler bei Code mit SubStrings für mich nicht auffindbar. Java Basics - Anfänger-Themen 4
S Kriege Fehler "Exception in thread" beim Benutzen von SubStrings. Java Basics - Anfänger-Themen 2
J subStrings zu int Array umwandeln? Java Basics - Anfänger-Themen 19
A Fahrzeug ID in substrings teilen und abgleichen Java Basics - Anfänger-Themen 9
G Substrings in regulärem Ausdruck Java Basics - Anfänger-Themen 2
T Substrings in Strings ersetzen ohne java.lang.String Java Basics - Anfänger-Themen 8
J Ähnlichen String in Liste finden Java Basics - Anfänger-Themen 6
B Alle Zahlen finden, die 3 bestimmte Ziffern enthalten? Java Basics - Anfänger-Themen 9
D Kleinste Zahl in Array finden die vorher noch errechnet werden müssen. Java Basics - Anfänger-Themen 4
Say Fehlenden Code finden in einer while-Schleife? Java Basics - Anfänger-Themen 11
J for Schleife kleinste Zufallszahl finden Java Basics - Anfänger-Themen 25
Substring in einem String finden Java Basics - Anfänger-Themen 13
B Den Dateipfad einer Java Datei durch Code in Selbiger finden? Java Basics - Anfänger-Themen 10
G Position einer unbekannten 3-stelligen-Zahl in einem String finden Java Basics - Anfänger-Themen 15
districon Java Nachhilfe - wo finden? Java Basics - Anfänger-Themen 9
sserio Rekursion größten Primfaktor finden funktioniert nicht Java Basics - Anfänger-Themen 8
P9cman Char Index rekursiv finden Java Basics - Anfänger-Themen 4
M Datums-Palindrome finden Java Basics - Anfänger-Themen 9
H Primzahlen finden - Zeit optimieren Java Basics - Anfänger-Themen 34
B in einem Array den nächstgelegenen Wert zu einem eingabewert finden Java Basics - Anfänger-Themen 8
B String - Wörter finden, welches Punkt und entsprechender Pre / Suffix hat? Java Basics - Anfänger-Themen 30
S Schwachstelle finden Java Basics - Anfänger-Themen 11
D kleinste Wurzel finden Java Basics - Anfänger-Themen 9
CptK Richtigen Pfad beim einlesen von Datei finden Java Basics - Anfänger-Themen 2
Devin Wo kann man einen Java Lehrplan finden? Java Basics - Anfänger-Themen 5
Y Wie kann ich ein Element in einer toString finden. Java Basics - Anfänger-Themen 2
V Beliebige Dreistellige Zahl Teiler finden Java Basics - Anfänger-Themen 4
J Lösungen zu einem Lückentext finden Java Basics - Anfänger-Themen 0
S Input/Output Reader/Writer finden file nicht Java Basics - Anfänger-Themen 3
S Streams - kleinstes Element finden Java Basics - Anfänger-Themen 4
L Koordinate mit meisten Überlappungen in 3D-Raum finden Java Basics - Anfänger-Themen 9
KogoroMori21 Größten gemeinsamen Teiler finden Java Basics - Anfänger-Themen 7
F Methoden Bitte Helft mir meinen Fehler zu finden. Möchte in diesem Bankenprogramm durch die Konsoleneingabe auswählen welches Konto reduziert und welches erhö Java Basics - Anfänger-Themen 17
Kirby.exe Fehlende Int Werte aus Array mit streams finden Java Basics - Anfänger-Themen 19
I Preis finden für ein Uber-App(?) Java Basics - Anfänger-Themen 3
D Binärbaum Blätter finden und Ausgeben Java Basics - Anfänger-Themen 22
L Classpath Alle Dateien im Classpath finden Java Basics - Anfänger-Themen 4
O Suchbaum Elternknoten finden Level eines Knoten bestimmen Java Basics - Anfänger-Themen 24
H pfad finden Java Basics - Anfänger-Themen 12
G Excle datei aus resources folder finden und lesen Java Basics - Anfänger-Themen 5
M Duplikate in Array finden... Java Basics - Anfänger-Themen 9
A Mit Rekursion Zufallszahlen erstellen und größte finden Java Basics - Anfänger-Themen 5
S Maxium aus einer File finden Java Basics - Anfänger-Themen 12
R HTTP-Links in Java Class finden Java Basics - Anfänger-Themen 3
C Finden mehrerer Lösungen Java Basics - Anfänger-Themen 0
L Backupdateien finden Java Basics - Anfänger-Themen 8
D doc.seect jsouo bestimmtes class element finden Java Basics - Anfänger-Themen 1
N Anfang eine Array Schleife finden Java Basics - Anfänger-Themen 18
D Erste Schritte Aktivsten Zweistündigen Abschnitt finden Java Basics - Anfänger-Themen 35
I Richtige Java-Version finden? Java Basics - Anfänger-Themen 17
DaCrazyJavaExpert Alle Zahlenkombinationen aus 9 zahlen finden Java Basics - Anfänger-Themen 17
S Erste Schritte Zwischen zwei Punkten ein Minimumpkt./Maxima finden Java Basics - Anfänger-Themen 1
M Denn dichtesten Wert finden Java Basics - Anfänger-Themen 3
N Objekte in ArrayList finden Java Basics - Anfänger-Themen 10
D Die Zahl in der Mitte finden Java Basics - Anfänger-Themen 20
kilopack15 Größte zahl eines Arrays finden Java Basics - Anfänger-Themen 1
H Fehler finden Java Basics - Anfänger-Themen 5
R Best Practice Palindrom in einem Text finden Java Basics - Anfänger-Themen 18
M Kleinsten Index in Array finden Java Basics - Anfänger-Themen 6
S Objekt finden und benutzen Java Basics - Anfänger-Themen 3
C Lottospiel kann Fehler nicht finden Java Java Basics - Anfänger-Themen 6
F System kann die Datei nicht finden Java Basics - Anfänger-Themen 7
D Werte in eckige Klammern finden Java Basics - Anfänger-Themen 3
S Input/Output Buchstaben in Eingabe finden und ausgeben Java Basics - Anfänger-Themen 5
A regulären Ausdruck mit Hilfe der Klasse Scanner in einem String finden Java Basics - Anfänger-Themen 2
N Objekt in einer Liste finden? Java Basics - Anfänger-Themen 3
C Finden und verändern Java Basics - Anfänger-Themen 1
T Erste Schritte Elemente finden, deren Name erst "zusammengesetzt" wird Java Basics - Anfänger-Themen 8
A Max finden und umtauschen Java Basics - Anfänger-Themen 2
K String in String-Array finden Java Basics - Anfänger-Themen 7
S Baumstruktur: tiefsten Knoten finden Java Basics - Anfänger-Themen 3
D Ein Objekt in einem Baum finden und ausgeben. Java Basics - Anfänger-Themen 4
F Erste Schritte Hilfe beim Algorithmus finden Java Basics - Anfänger-Themen 8
D Zahl in einem String finden Java Basics - Anfänger-Themen 4
C Methoden Diagonalen am best. Punkt im zweidimensionales array finden Java Basics - Anfänger-Themen 3
A Compiler-Fehler Kann Fehler nicht finden Java Basics - Anfänger-Themen 2
R Fehler finden die 2. Java Basics - Anfänger-Themen 7
N Bug finden im Programm Java Basics - Anfänger-Themen 13
P letzte Datei finden Java Basics - Anfänger-Themen 18
M Zwei gleiche Eintraege in ArrayList finden Java Basics - Anfänger-Themen 15
J Inhalt in einem Text-File finden und in ein Array schreiben Java Basics - Anfänger-Themen 5
I String in .txt finden Java Basics - Anfänger-Themen 9
T Wörter mit @ als Zeichen finden Java Basics - Anfänger-Themen 13
J Methoden Kann Fehler nicht finden Java Basics - Anfänger-Themen 6
M Letztes Element im Array finden Java Basics - Anfänger-Themen 3
R Erste Schritte Minimum und Maximum in Array finden Java Basics - Anfänger-Themen 29
H Schnell HTML-Tags finden Java Basics - Anfänger-Themen 5
Kenan89 Wo sind die Java Standard Library Source Codes zu finden? Java Basics - Anfänger-Themen 5
R Rekursive Methode, Files finden Java Basics - Anfänger-Themen 2
S brauche hilfe beim fehler finden Java Basics - Anfänger-Themen 2
B Dokumentation in der jre-Library finden Java Basics - Anfänger-Themen 9
T Datentypen Knoten Großvater finden? Java Basics - Anfänger-Themen 12
A Fehler finden und Ausgabe Java Basics - Anfänger-Themen 14
P Key anhand von Value finden (Hashtable) Java Basics - Anfänger-Themen 3
Q ProcessBuilder kann datei nicht finden Java Basics - Anfänger-Themen 2
K taschenrechner - Fehler beim Kürzen eines Bruches finden Java Basics - Anfänger-Themen 20
S Richtige String-Variable finden Java Basics - Anfänger-Themen 3
C Fehler in Java-Code finden Java Basics - Anfänger-Themen 17
D Geeigneten Speicherort finden ? Java Basics - Anfänger-Themen 11
K Groessere Zahl finden und berechnen?? Java Basics - Anfänger-Themen 6

Ähnliche Java Themen

Neue Themen


Oben