String generieren

Status
Nicht offen für weitere Antworten.
B

Baaron

Gast
ein String A besteht aus n zeichen.

der zweite String B sollte verschiedene kombinationen aus "g,l,r" für jedes zeichen generiert werden. jedes zeichen kann g oder l oder r annehmen.
beispiel n=3

d.h. String B sollte verschiedenste Reihenfolgen annehmen ggg,ggl,ggr,rgl, usw...also er sollte nicht alle möglichkeiten durchgehen sondern zufällig irgendeine erzeugen.
kann man dem algo auch beibringen, dass er sich eine kombination merkt, wenn sie gut war? sobald im String A die folge kommt, für die er schon eine Kombination gemacht hatte, soll er die auch nehmen.

es wird nämlich anhand von der kombination im String B eine Matrix angelegt und mit Werten aus String A ausgefüllt.
g=grade,l=links,r=rechts. dort sollten bestimmte Sachen gezählt werden und wenn die anzahl der Treffer hoch ist, dann war die Kombination im STring B gut.

ich hoffe es gibt jemanden der sowas kann :)
ich nämlich nicht... :) hab erst vor paar wochen mit java angefangen..und muss sowas realisieren...(steckt noch was dahinter) :)
 

enriico

Mitglied
Code:
public class Combinations {

    public static void comb1(String s) { comb1("", s); }

    private static void comb1(String prefix, String s) {
        if (s.length() > 0) {
            System.out.println(prefix + s.charAt(0));
            comb1(prefix + s.charAt(0), s.substring(1));
            comb1(prefix,               s.substring(1));
        }
    }  

    public static void comb2(String s) { comb2("", s); }
    private static void comb2(String prefix, String s) {
        System.out.println(prefix);
        for (int i = 0; i < s.length(); i++)
            comb2(prefix + s.charAt(i), s.substring(i + 1));
    }  


    public static void main(String[] args) {
       int N = 3;
       String alphabet = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ";
       String elements = alphabet.substring(0, N);

       comb1(elements);
       System.out.println();

       comb2(elements);
       System.out.println();
    }

}

ist es das, was du wolltest?
 
B

Baaron

Gast
ja so ähnlich
aber nicht
g
gl
glr
sondern
ggg
ggl
ggr
glg
glr
usw...aber halt random erzeugt..es sind sonst 3^3 kombinationen..wenn im String A dann 1000 zeichen sind, dann sind es 3^1000 :) und das dauert..also es sollte so 100 mal durchlaufen und dabei verschiedene kombinationen erzeugt werden
 

enriico

Mitglied
Ich habe da noch was von meiner Studienzeit gefunden. Es ist zwar etwas viel Code, aber den kannst du
problemlos umschreiben. Ich habe hier eine eigene Queue und einen eigenen Stack implementiert.
Du kannst natürlich auch den Stack resp. die Queue von Java nehmen, dann musst du einfach die print Methode neu schreiben.

Gruss

Code:
public class DequeEmptyException extends RuntimeException
{
  public DequeEmptyException(String err)
  {
    super(err);
  }
}

Code:
public class EmptyQueueException extends RuntimeException
{
  public EmptyQueueException(String err)
  {
    super(err);
  }
}

Code:
public class EmptyStackException extends RuntimeException
{
  public EmptyStackException(String err)
  {
    super(err);
  }
}

Code:
public class Permutationen
{
  public void permutationen(QueueImpl q, StackImpl s)
  {
    if (q.isEmpty())
    {
      System.out.print("Permutation : ");
      s.print();
      System.out.print("\n");
    }
    else
    {
      for (int i=1; i<=q.size(); i++)
      {
        s.push(q.dequeue());
        permutationen(q, s);
        q.enqueue(s.pop());
      }
    }
  }
  
  public static void main(String[] args)
  {
    Permutationen perm = new Permutationen();
    QueueImpl q = new QueueImpl();
    q.enqueue("a");
    q.enqueue("b");
    q.enqueue("c");
    q.enqueue("d");
    StackImpl s = new StackImpl();
    perm.permutationen(q,s);
  }
}

Code:
public interface Queue
{
 /**
  * Returns the number of elements in the queue.
  * @return number of elements in the queue.
  */
  public int size();
 /**
  * Returns whether the queue is empty.
  * @return true if the queue is empty, false otherwise.
  */
  public boolean isEmpty();
 /**
  * Inspects the element at the front of the queue.
  * @return element at the front of the queue.
  * @exception EmptyQueueException if the queue is empty.
  */
  public Object front() throws EmptyQueueException;
 /**
  * Inserts an element at the rear of the queue.
  * @param element new element to be inserted.
  */
  public void enqueue (Object element);
 /**
  * Removes the element at the front of the queue.
  * @return element removed.
  * @exception EmptyQueueException if the queue is empty.
  */
  public Object dequeue() throws EmptyQueueException;
}

Code:
public class QueueImpl implements Queue
{
  private Object[] array;
  private int size;
  
  public QueueImpl()
  {
    array = new Object[2];
    size = 0;
  }
  
  public int size()
  {
    return size;
  }

  public boolean isEmpty()
  {
    return (size == 0) ? true : false;
  }

  public Object front() throws EmptyQueueException
  {
    return array[0];
  }

  public void enqueue(Object element)
  {
    if (array.length <= size)
    {
      enlargeArray();
    }
    array[size++] = element;
  }

  public Object dequeue() throws EmptyQueueException
  {
    if (size > 0)
    {
	    Object obj = array[0];
	    for (int i=1; i<size; i++)
	    {
	      array[i-1] = array[i];
	    }
	    size--;
	    if((size >= 2) && (size <= array.length/2))
	    {
	      reduceArray();
	    }
	    return obj;
    }
    else
    {
      throw (new EmptyQueueException("Could not dequeue because queue is empty."));
    }
  }
  
  private void enlargeArray()
  {
    Object[] prev = array;
    array = new Object[prev.length*2];
    System.out.println("Enlarging array from "+prev.length+" to "+array.length);
    for (int i=0; i<prev.length; i++)
    {
      array[i] = prev[i];
    }
  }
  
  private void reduceArray()
  {
    Object[] prev = array;
    if (prev.length%2 == 0)
    {
      array = new Object[prev.length/2];
    }
    else
    {
      array = new Object[prev.length/2+1];
    }
    System.out.println("Reducing array from "+prev.length+" to "+array.length);
    for (int i=0; i<array.length; i++)
    {
      array[i] = prev[i];
    }
  }
  
  public void print()
  {
    if (size==0)
    {
      System.out.println("The queue is empty.");
    }
    else
    {
      for (int i=0; i<size; i++)
      {
        System.out.print(array[i]);
      }
    }
  }
  
  public static void main(String[] args)
  {
    QueueImpl queue = new QueueImpl();
    for (int i=0; i<20; i++)
    {
      System.out.println("enqueue(): "+i);
      queue.enqueue(new Integer(i));
    }
    System.out.println("front(): "+(Integer)queue.front());
    while (!queue.isEmpty())
    {
      System.out.println("dequeue(): "+(Integer)queue.dequeue());
    }
  }
}

Code:
public interface Stack
{
 /**
  * Return the number of elements in the stack.
  * @return number of elements in the stack.
  */
  public int size();
 /**
  * Return whether the stack is empty.
  * @return true if the stack is empty, false otherwise.
  */
  public boolean isEmpty();
 /**
  * Inspect the element at the top of the stack.
  * @return top element in the stack.
  * @exception EmptyStackException if the stack is empty.
  */
  public Object top() throws EmptyStackException;
 /**
  * Insert an element at the top of the stack.
  * @param element element to be inserted.
  */
  public void push (Object element);
 /**
  * Remove the top element from the stack.
  * @return element removed.
  * @exception EmptyStackException if the stack is empty.
  */
  public Object pop() throws EmptyStackException;
}

Code:
import java.util.LinkedList;

public class StackImpl implements Stack
{
  private LinkedList list;

  public StackImpl()
  {
    list = new LinkedList();
  }
  
  public int size()
  {
    return list.size();
  }

  public boolean isEmpty()
  {
    return list.isEmpty();
  }

  public Object top() throws EmptyStackException
  {
    try
    {
      return list.getLast();
    }
    catch (Exception ex)
    {
      throw (new EmptyStackException("Could not get top of stack because stack is empty."));
    }
  }

  public void push(Object element)
  {
    list.addLast(element);
  }

  public Object pop() throws EmptyStackException
  {
    try
    {
      return list.removeLast();
    }
    catch (Exception ex)
    {
      throw (new EmptyStackException("Could not remove top of stack because stack is empty."));
    }
  }
  
  public void print()
  {
    if (list.size()==0)
    {
      System.out.println("The stack is empty.");
    }
    else
    {
      for (int i=0; i<list.size(); i++)
      {
        System.out.print(list.get(i));
      }
    }
  }
  
  public static void main(String[] args)
  {
    StackImpl stack = new StackImpl();
    for (int i=0; i<20; i++)
    {
      System.out.println("push(): "+i);
      stack.push(new Integer(i));
    }
    System.out.println("top(): "+(Integer)stack.top());
    while (!stack.isEmpty())
    {
      System.out.println("pop(): "+(Integer)stack.pop());
    }
  }
}
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
M Zufälligen String generieren und alle 5 Minuten ändern Allgemeine Java-Themen 2
N String generieren Allgemeine Java-Themen 3
MQue List<String> aus List<Object> generieren Allgemeine Java-Themen 2
C EML Email Text in String wandeln Allgemeine Java-Themen 9
OnDemand Java String in Hashmap als Key NULL Allgemeine Java-Themen 27
JAnruVA Datentypen Berechneten String-Wert in Double umwandeln um weiter zu rechnen Allgemeine Java-Themen 7
M String Allgemeine Java-Themen 10
M Suche nach String mit unbekannten characters Allgemeine Java-Themen 53
kodela String kann nicht zu Pfad konvertiert werden Allgemeine Java-Themen 16
melaniemueller Einzelne Zeile aus einer txt Datei in einem String speichern Allgemeine Java-Themen 12
E Objekte in einen String packen und wieder laden Allgemeine Java-Themen 5
M Map<String,String>funktioniert nicht richtig Allgemeine Java-Themen 4
O String in Long Hexerdezimal umwandel Allgemeine Java-Themen 14
N String vergleichen. Allgemeine Java-Themen 27
P String.replace() funktioniert nicht? Allgemeine Java-Themen 3
SaschaMeyer Arbeitet String.split falsch? Allgemeine Java-Themen 4
M Switches ohne String Allgemeine Java-Themen 18
AmsananKING String Iteration Allgemeine Java-Themen 5
S Shuffle String aus if-clause Allgemeine Java-Themen 11
Besset Variablen Ist String = "" + int inordnung? Allgemeine Java-Themen 6
M Map <Long, String> zu Map<String, Long> Allgemeine Java-Themen 9
S String Encoding Verständnisproblem Allgemeine Java-Themen 22
N Prüfen, ob ein String 2x das selbe Zeichen hat Allgemeine Java-Themen 10
SaftigMelo Bug Fixen von String-spliten Allgemeine Java-Themen 8
Monokuma String List nach Zahlen und Worten sortieren Allgemeine Java-Themen 9
Kingamadeus2000 Alle mehrfach vorkommenden Buchstaben rekursiv aus einem String entfernen. Allgemeine Java-Themen 6
YohnsonM String - Aufteilung und Nutzung einzelner Chars Allgemeine Java-Themen 7
O Formatierte String ausgabe bei vier Variablen in einer Zeile Allgemeine Java-Themen 1
S String umbenennen: wie? Allgemeine Java-Themen 4
x46 String Format Fehler Allgemeine Java-Themen 2
S ISO 8601 -> getter / setter String Allgemeine Java-Themen 3
L String zu repräsentativen Wert Allgemeine Java-Themen 0
H Array mit dem Datentype String[] initializieren Allgemeine Java-Themen 7
L ArrayList mit String Arrays in ein Array umwandeln Allgemeine Java-Themen 1
L regex ganzer string? Allgemeine Java-Themen 2
L Ist ein string ein erlaubter variabel name? Allgemeine Java-Themen 2
Z JNA Cpp-DLL String Verwendung Allgemeine Java-Themen 2
A String auf Zahlen überprüfen Allgemeine Java-Themen 5
N String Array Eingabe Allgemeine Java-Themen 6
MiMa Datum von String zu LocalDateTime Allgemeine Java-Themen 8
W String -> byte[] -> String - Sieht jemand was ich nicht sehe? Allgemeine Java-Themen 10
R char aus String entfernen Allgemeine Java-Themen 10
LimDul Mittels Streams aus Strings A B C den String A, B und C machen Allgemeine Java-Themen 12
M Programm erkennt String aus .txt Datei nicht Allgemeine Java-Themen 3
P einen public <Optinal String> in einer anderen Klasse mit einem Int vergleichen Allgemeine Java-Themen 2
S Ini Text aus String parsen Allgemeine Java-Themen 1
T String-Manipulation beim Ablauf in Eclipse und als JAR-File Allgemeine Java-Themen 8
M String lässt sich nicht Zusammenfügen Allgemeine Java-Themen 10
Drachenbauer Wie kann ich das Wort "concrete" in einem String durch ein anderes Wort ersetzen lassen? Allgemeine Java-Themen 5
R Schlüsselworte "Throw new exception" gibt nicht den String als Fehlermeldung aus Allgemeine Java-Themen 2
R Variablen String mit split-Funktion aufteilen Allgemeine Java-Themen 7
F Datei in String-Array einlesen Allgemeine Java-Themen 8
S Marker aus String ermitteln Allgemeine Java-Themen 5
T Objekt mit String und Int aus TxT Datei erstellen Allgemeine Java-Themen 23
M Bei String.format ein Komma statt einem Punkt ausgeben lassen Allgemeine Java-Themen 1
S MSSQL Exception & Connection String Allgemeine Java-Themen 19
B Bei Email: FW / AW... - Hilfe bei String suche Allgemeine Java-Themen 21
J String - Vergleiche Allgemeine Java-Themen 7
K Aus String zwei Jahreszahlen auslesen Allgemeine Java-Themen 18
Drachenbauer Wie kann eine vorgegebene Farbe über einen String erkannt werden? Allgemeine Java-Themen 11
G CSV in String Allgemeine Java-Themen 7
P String-Verschlüsselung - Frage zur Sicherheit Allgemeine Java-Themen 21
K Methodenaufruf mit String / String zu Objekt konvertieren Allgemeine Java-Themen 8
D Erste Schritte Fehler mit negativen und 0 Zahlen im String Allgemeine Java-Themen 6
Xge Replace x Zeichen aus String Allgemeine Java-Themen 2
coolian warum bekomme ich ein string index out of bounds exception Allgemeine Java-Themen 17
F In String 2 Buchstaben vertauschen Allgemeine Java-Themen 2
J Class Decompile als String (Procyon) Allgemeine Java-Themen 2
I Datentypen String in class sicher verwahren Allgemeine Java-Themen 17
J Falls der String ein "X" beinhaltet Allgemeine Java-Themen 2
T String mehrere Worte Allgemeine Java-Themen 2
D String Groß-/Kleinschreibung Allgemeine Java-Themen 2
D String und Klassenvariable Allgemeine Java-Themen 6
Aruetiise Funktion(y = mx+n) in String speichern und berechnen Allgemeine Java-Themen 9
C String in Objektnamen umwandeln Allgemeine Java-Themen 3
E Variablen Aus .txt ausgelesener string mit if() überprüfen? Allgemeine Java-Themen 2
L String-Schema-Aufspaltung Allgemeine Java-Themen 2
E String in Zahl umwandeln, ohne Befehl Integer.parseInt Allgemeine Java-Themen 3
L String splitten und multiplizeren Allgemeine Java-Themen 10
G String mit umbekannter länge splitten. Allgemeine Java-Themen 2
S Einzigartigen String in Datenbank finden und löschen Allgemeine Java-Themen 23
A Byte zu String Allgemeine Java-Themen 4
B Von String zu <Objekt> ||Speichern/Laden Allgemeine Java-Themen 17
T Komplexitätsoptimierung String vergleich Allgemeine Java-Themen 4
heinz ketchup String im JLabel ausgeben und erneuern Allgemeine Java-Themen 6
S Input/Output Beste Möglichkeit einen String in einen Datei zu Schreiben Allgemeine Java-Themen 2
V Eingegeben String Splitten und in Integer umwandeln Allgemeine Java-Themen 2
L Decrypt String Allgemeine Java-Themen 1
X Variablen AtmicLong größer als String ? Allgemeine Java-Themen 4
S String literal und Referenzvariablen Allgemeine Java-Themen 6
J Datentypen Absätze mit String im Word Dokument Allgemeine Java-Themen 3
D "Paste" String doppelt Allgemeine Java-Themen 14
E String Frage Allgemeine Java-Themen 9
T String aus While Schleife für ganze Klasse sichtbar machen Allgemeine Java-Themen 5
D JSON to String Allgemeine Java-Themen 31
M String automatisch in nächste Zeile umbrechen (Graphics) Allgemeine Java-Themen 6
U Methoden Algorithmus MergeSort String [ ] array sortieren programmieren Allgemeine Java-Themen 17
T Swing Font String Pixellänge Allgemeine Java-Themen 1
G Substrings in einen String zusammenfassen Allgemeine Java-Themen 5
Tommy Nightmare String.replaceAll(...) fehlerhaft? Allgemeine Java-Themen 3

Ähnliche Java Themen

Neue Themen


Oben