Problem mit meiner generischen Klasse

Status
Nicht offen für weitere Antworten.

sidex

Mitglied
hallo leute ich hab folgendes problem.

ich muss ein AVL baum schreiben das Comparable implementiert und generisch ist.
nun so sehen meine zwei Klassen aus:

Code:
import java.lang.*;

public class AVLnode implements Comparable<Integer>
{
	public AVLnode left;   //Referenz auf das linke Kindknoten
	public AVLnode right;  //Referenz auf das rechte Kindknoten
	AVLnode top;     //Referenz auf das Elternknoten
	int level;
	int data;
    
	public AVLnode (AVLnode left, AVLnode right, int data)
	{
		this.left = left;
		this.right = right;
		this.data = data;
		
		AVLnode puffer = null;
		
		if ( left != null )
			puffer = left;
		else
			puffer = right;
			
		if ( puffer != null )
		{
			while ( puffer != null )
			{
				++level;
				puffer = puffer.top;
			}
		}
		else
			level = 0;
	}
	
	public int slope (int n1, int n2)
	{
		return Math.abs(n1 - n2);
	}
	
    public int compareTo(Integer n1)
    {
        if (this.data == n1)
            return 0;
        else 
            if ( this.data < n1)
                return -1;
            else 
                return   1;
    }
		
}

Code:
public class AVLtree<T extends AVLnode & Comparable<Integer>>
{
	private T root;
	int Llevel;
	int Rlevel;
	int compData;
	
	public AVLtree()
	{
		root = null;
	}
	
	public void search(int value)
	{
		search2( root, value );
	}
	
	private T search2( T root, int value)
	{
		if ( root == null )
			return null;
		else
			compData = root.compareTo( value );
			switch ( compData )
			{
				case  1 :		return search2(root.right, value);
								break;
				case-1 :	return search2(root.left, value);
								break;
				case  0 :		return root;
								break;
			}
	}
	
	public void rebalance()
	{
		
	}
	
	public void depth( T root)
	{
		
	}
	
	public void insert()
	{
		
	}
}

beim build bekomm ich folgende fehlerausgabe:

Code:
Compiling 3 source files to /Users/sidex/Stree/bin
/Users/sidex/Stree/src/AVLtree.java:26: search2(T,int) in AVLtree<T> cannot be applied to (AVLnode,int)
				case  1 :		return search2(root.right, value);
                                                               ^
/Users/sidex/Stree/src/AVLtree.java:28: search2(T,int) in AVLtree<T> cannot be applied to (AVLnode,int)
				case-1 :	return search2(root.left, value);
                                                       ^
2 errors

kann mir bitte einer sagen wo der fehler ist? ich raff generics einfach nicht :(
ich hab schon alles mögliche ausprobiert.
also bitte hilft mir.

mfg sidex

edit: was ich vergessen habe zu sagen. eigentlich sollte die AVLtree klasse so aussehen:

AVLtree<T extends Comparable<Integer>

aber dann bekomm ich bei build ne meldung dass er das Objekt root.right und root.left nicht kennt.
aber wieso meldet der das? werden bei den generischen sachen die Typen nicht erst während der Laufzeit bekannt gegeben?
 

kama

Top Contributor
Hi,

deine Implementierung arbeitet mit "Integer" und der Aufruf verwendet "int" ?

MfG
Karl Heinz
 
B

Beni

Gast
"search2" erwartet ein T (eine Subklasse von AVLNode), und kein AVLNode. AVLNode.left (oder right) ist aber ein AVLNode und kein T.

Es ist dieselbe Situation wie wenn du einer Methode "setName( String name )" lediglich ein Object übergeben möchtest.

Der ganze Widerspruch kann aufgelöst werden, wenn der AVLNode auch noch ein bisschen generischer wird:
Code:
package forum;

public class AVLNode<T extends AVLNode<T>> implements Comparable<Integer>
{
   public T left;   //Referenz auf das linke Kindknoten
   public T right;  //Referenz auf das rechte Kindknoten
   T top;     //Referenz auf das Elternknoten
   int level;
   int data;
   
   public AVLNode (T left, T right, int data)
   {
      this.left = left;
      this.right = right;
      this.data = data;
      
      T puffer = null;
      
      if ( left != null )
         puffer = left;
      else
         puffer = right;
         
      if ( puffer != null )
      {
         while ( puffer != null )
         {
            ++level;
            puffer = puffer.top;
         }
      }
      else
         level = 0;
   }
   
   public int slope (int n1, int n2)
   {
      return Math.abs(n1 - n2);
   }
   
    public int compareTo(Integer n1)
    {
        if (this.data == n1)
            return 0;
        else
            if ( this.data < n1)
                return -1;
            else
                return   1;
    }
      
}

Code:
package forum;

public class AVLTree<T extends AVLNode<T> & Comparable<Integer>>
{
   private T root;
   int Llevel;
   int Rlevel;
   int compData;
   
   public AVLTree()
   {
      root = null;
   }
   
   public void search(int value)
   {
      search2( root, value );
   }
   
   private T search2( T root, int value)
   {
      if ( root == null )
         return null;
      else
         compData = root.compareTo( value );
         switch ( compData )
         {
            case  1 : return search2(root.right, value);
            case -1 : return search2(root.left, value);
            case  0 : return root;
            default: throw new IllegalStateException( "Offenbar würde ich hier besser < 0, > 0 und == 0 testen..." );
         }
   }
   
   public void rebalance()
   {
      
   }
   
   public void depth( T root)
   {
      
   }
   
   public void insert()
   {
      
   }
}

----------
Ich frage mich allerdings, wieso es für den Benutzer wichtig sein sollte, welcher Typ Node der Tree verwendet? Das Interface "Comparable" könnte allgemeiner, eleganter eingesetzt werden, so dass der Baum mehr Datentypen speichern kann.
Hier nur ein Überblick, wie das aussehen könnte:
Code:
public class AVLTree<T extends Comparable<T>>{
    private AVLNode<T> root;
    
    public boolean search( T value ){
        return search( root, value );
    }
    
    private boolean search( AVLNode<T> node, T value ){
        if( node == null )
            return false;
        
        int compare = node.getValue().compareTo( value );
        if( compare == 0 )
            return true;
        
        if( compare < 0 )
            return search( node.getLeft(), value );
        else
            return search( node.getRight(), value );
    }
}


public class AVLNode<T extends Comparable<T>>{
    private T value;
    private AVLNode<T> left, right;
    
    public AVLNode<T> getLeft() {
        return left;
    }
    public AVLNode<T> getRight() {
        return right;
    }
    public T getValue() {
        return value;
    }
}
 
G

Guest

Gast
hi danke schon mal! aber was muss ich dann als Typ an AVLnode übergeben? muss ich dann neue node-Klasse erstellen die von AVLnode erbt und diese an an AVLnode übergeben oder wie?

was wenn ich statt extends super schreibe? dann sollte er doch AVLnode erwarten? und stattdessen bekomm ich ne meldung dass ein < und { fehlt.

gibt es eigentlich irgendwo ein artikel wo generics gut erklärt ist? weil generics ist bis jetzt meine größte schwäche.

mfg sidex
 
B

Beni

Gast
Der Node benötigt denselben Typ den schon der Tree hat.

Code:
public class Tree<T>{
  public void blabla( T value ){
    root = new AVLNode<T>( value ); // << hier der Typ vom Tree verwenden
  }
}

Der Witz an all den Generics ist, dass hier gerade keine Unterklassen notwendig sind :wink:

Ich denke, das Tutorial hier wird so ziemlich all deine Fragen beantworten (auch das mit super oder extends).
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
krgewb Problem mit Umlauten und Eszett bei InputStream Allgemeine Java-Themen 3
Max246Sch Backtracking Problem Box Filler Allgemeine Java-Themen 6
NightVision402 VisualVM Startskript Problem Allgemeine Java-Themen 3
javaBoon86 Email Server Connection Problem Allgemeine Java-Themen 1
F Problem mit PDFBOX Library Allgemeine Java-Themen 1
A Java modul Problem Allgemeine Java-Themen 4
D Read JSON File Problem Allgemeine Java-Themen 9
urmelausdemeis Exception in thread "main" java.lang.Error: Unresolved compilation problem: Allgemeine Java-Themen 7
J Problem mit JasperReports Allgemeine Java-Themen 8
M log4j Problem mit jlink Allgemeine Java-Themen 19
8u3631984 Problem beim Mocken von Record Klassen Allgemeine Java-Themen 4
torresbig Website login Problem - Jsoup, wie bisher, klappt nicht! Allgemeine Java-Themen 31
P Selenium . getText Problem Allgemeine Java-Themen 9
A Jar zu Exe Problem Allgemeine Java-Themen 13
sserio Variablen Liste erstellt und ein Problem mit dem Index Allgemeine Java-Themen 6
S Folgendes Problem bei einem Programm Allgemeine Java-Themen 1
stormyark Problem beim Klassen erstellen Allgemeine Java-Themen 1
A Thread.sleep Problem Allgemeine Java-Themen 2
A Problem bei der Nachbarschafttest Allgemeine Java-Themen 11
Splayfer Problem: no main manifest attribute Allgemeine Java-Themen 3
G javamail Problem beim Empfangen von Nachrichten Allgemeine Java-Themen 3
Splayfer JDA Problem mit MessageCounter Allgemeine Java-Themen 0
Splayfer Problem mit BufferedWriter Allgemeine Java-Themen 3
F Streams als Alternative für dieses Problem ? Allgemeine Java-Themen 15
N Maven Problem mit Datenbanktreiber (H2 Embedded) Allgemeine Java-Themen 12
T Problem beim Umwandeln in eine Jar-Datei Allgemeine Java-Themen 3
B Einfach Elemente zweier Arraylisten kreuz und quer vergleichen, min und max Problem? Allgemeine Java-Themen 16
C ArrayList Problem Allgemeine Java-Themen 3
kev34 nim-Spiel problem Allgemeine Java-Themen 1
D Firebase retrieve data Problem, Child Element wird nicht angesprochen Allgemeine Java-Themen 0
G Welches Problem besteht bei den Typparametern? Allgemeine Java-Themen 5
temi Problem mit Aufrufreihenfolge bei Vererbung Allgemeine Java-Themen 3
Sumo_ow "ArrayIndexOutofBoundsException: 2" Array Problem Allgemeine Java-Themen 6
T PIM basierend auf netbeans via AnyDesk Problem Allgemeine Java-Themen 3
xGh0st2014 Problem mit Java Array Allgemeine Java-Themen 1
Kirby.exe Verständnis Problem bei Rucksack Problem Allgemeine Java-Themen 6
B Eclipse-Lombok-Problem Allgemeine Java-Themen 19
I Input/Output ObjectOutputStream - Problem Allgemeine Java-Themen 7
1 Multiple Choice Knapsack- Problem Allgemeine Java-Themen 2
kodela Problem mit strukturiertem Array Allgemeine Java-Themen 18
E Problem mit Gridlayout und Button Allgemeine Java-Themen 2
A Array Problem Allgemeine Java-Themen 8
bueseb84 Problem Allgemeine Java-Themen 0
S Problem mit Arrays Allgemeine Java-Themen 1
D Nullpointer Exception Problem Allgemeine Java-Themen 5
B Problem mit meinen Klassen Allgemeine Java-Themen 6
A HashMap Methode "get()"-Problem Allgemeine Java-Themen 28
J Problem beim Umstellen auf Java jdk 13 Allgemeine Java-Themen 3
J Problem bei Install java 13 Allgemeine Java-Themen 3
X Profitable Reise Problem Allgemeine Java-Themen 32
A Problem beim öffnen von Java-Installern Allgemeine Java-Themen 1
Dann07 Problem mit JavaMail API Allgemeine Java-Themen 26
J Problem beim Generischen Klassen und Interfaces Allgemeine Java-Themen 2
L Klassen Algorithmus für das folgende Problem entwickeln? Allgemeine Java-Themen 30
J Clear-Problem Allgemeine Java-Themen 10
B Problem zu einem Java Projekt Allgemeine Java-Themen 6
S JFileChooser Problem Allgemeine Java-Themen 4
M Traveling Salesman - MST Heuristik Problem Allgemeine Java-Themen 4
J Traveling Salesman Problem Allgemeine Java-Themen 14
E Java Editor Problem mit 2er Exceptions Allgemeine Java-Themen 12
C code oder Bibliotheken für 2-Center Problem Allgemeine Java-Themen 4
M Salesman Problem - Bruteforce Algorithmus Allgemeine Java-Themen 23
S Methoden Problem mit NullPointerException Allgemeine Java-Themen 9
Javafan02 Problem mit if-clause Allgemeine Java-Themen 17
J Lombok Problem mit Konstruktoren bei Verberbung Allgemeine Java-Themen 1
kodela Event Handling Problem mit der Alt-Taste Allgemeine Java-Themen 16
W Threads Problem Allgemeine Java-Themen 15
D (Verständnis-)Problem mit Unterklasse Allgemeine Java-Themen 4
S Problem mit Generic bei unmodifiableCollection Allgemeine Java-Themen 4
S jserialcomm Problem Allgemeine Java-Themen 1
Flynn Thread-Problem... Allgemeine Java-Themen 2
J Generische Interface - Problem Allgemeine Java-Themen 3
G Problem beim GUI Allgemeine Java-Themen 9
L Applet Problem "security: Trusted libraries list file not found" ? Allgemeine Java-Themen 7
A OOP Problem beim Berechnen der größten Fläche eines Ringes Allgemeine Java-Themen 19
T Problem mit externen Datenbankzugriff über SSH Tunnel Allgemeine Java-Themen 4
F Problem beim Einlesen einer Textdatei Allgemeine Java-Themen 12
S Java OpenOffice Problem mit Windows-Benutzerwechsel Allgemeine Java-Themen 19
K Threads RAM Problem Allgemeine Java-Themen 20
P Operatoren Problem mit Zähler in recursiver Schleife Allgemeine Java-Themen 2
C Int Problem Allgemeine Java-Themen 8
C J2V8 NodeJs Java Bride Problem und Frage!?!? Allgemeine Java-Themen 1
J Problem bei Hashmap Key-Abfrage Allgemeine Java-Themen 4
C Webseiten Programm problem Allgemeine Java-Themen 5
M LocalDate Problem Allgemeine Java-Themen 4
J "Problem Objektorientierung" Allgemeine Java-Themen 20
geekex Problem Meldung! Was tun?! Allgemeine Java-Themen 19
T Klassen Override Problem Allgemeine Java-Themen 7
L Unbekanntes Problem Allgemeine Java-Themen 1
FrittenFritze Problem mit einer JComboBox, Event temporär deaktivieren Allgemeine Java-Themen 11
Blender3D Java Swing Programm Windows 10 Autostart Problem Allgemeine Java-Themen 2
F HTTPS Zertifikat Problem Allgemeine Java-Themen 3
M OpenCV KNearest Problem Allgemeine Java-Themen 0
Tommy Nightmare Project Euler: Problem 22 Allgemeine Java-Themen 2
C Abstrakte Klasse, lokale Variable-Problem Allgemeine Java-Themen 1
N Vererbung Design-Problem mit vorhandenen, von der Klasse unabhängigen Methoden Allgemeine Java-Themen 12
P Eclipse Projekt anlegen macht Problem Allgemeine Java-Themen 1
RalleYTN META-INF/services Problem Allgemeine Java-Themen 3
F Java Mail Problem: Authentifizierung wird nicht immer mitgeschickt Allgemeine Java-Themen 1
I Problem beim Aufrufen, von Objektmethoden/ -variablen Allgemeine Java-Themen 6

Ähnliche Java Themen

Neue Themen


Oben