• Keine Ergebnisse gefunden

Übung 01: Verkettete Liste

N/A
N/A
Protected

Academic year: 2022

Aktie "Übung 01: Verkettete Liste"

Copied!
1
0
0

Wird geladen.... (Jetzt Volltext ansehen)

Volltext

(1)

Übung Praktische Informatik: Datenstrukturen SS 2008

Übung 01: Verkettete Liste

Abgabetermin: 11.03.2008 12:00

Name: Matrikelnummer:

Gruppe: ❒ G1 (Wolfinger)

Aufgabe Punkte gelöst abzugeben schriftlich abzugeben elektronisch

Korr. Pkte

Aufgabe 01.1 12 ❏ Java-Programm

Testfälle und Ergebnisse

Java-Programm ❏

Aufgabe 01.1: Zahlenmenge als verkettete Liste

Implementieren Sie eine Zahlenmenge mit Hilfe einer linearen Liste (Hinweise: Ein Menge enthält niemals mehrere Exemplare der gleichen Zahl. Die Reihenfolge der Zahlen ist ohne Bedeutung).

class Set {

Node head; // first node in list public Set() { … }

… }

class Node {

int val; // value in node Node next; // next node in list public Node(int val) {… } }

Vervollständigen Sie die beiden Konstrukturen und implementieren Sie in der Klasse Set Klasse folgende Methoden:

void set(int val): fügt eine neue Zahl in die Menge ein, wenn diese Zahl noch nicht enthalten ist bool get(int val): prüft ob eine Zahl in der Menge enthalten ist

int size(): liefert die Anzahl der Zahlen in der Menge void remove(int val): entfernt eine Zahl aus der Menge Set clone(): liefert eine Kopie der Menge als neue Menge void print(): gibt eine Menge auf der Kommandozeile aus

Set intersect(Set s): liefert Schnittmenge aus this und s als neue Menge Set union(Set s): liefert Vereinigungsmenge aus this und s als neue Menge

Set range(int from, int to): liefert alle Zahlen, die im Bereich zwischen from und to liegen, als neue Menge (Bereichsgrenzen jeweils eingeschlossen >=, <=)

Beispiel: Gegeben sind die Mengen s1 und s2:

s1: { -9 -5 -4 -3 0 2 4 10 }

s2: { -5 -3 0 1 2 7 9 }

Folgende Operation auf diesen Mengen s1 und s2 sollen folgende Ergebnisse liefern:

s1.union(s2): { 10 4 -4 -9 9 7 2 1 0 -3 -5 } s1.intersect(s2): { 2 0 -3 -5 }

s1.range(0, 10): { 10 4 2 0 } s2.range(-10, 0): { 0 -3 -5 } s2.remove(0): { -5 -3 1 2 7 9 } s2.remove(2): { -5 -3 1 7 9 } s1.intersect(s2): { -3 -5 } Abzugeben ist:

Das Java-Programm

Testfälle und die Ergebnisse

Referenzen

ÄHNLICHE DOKUMENTE

Implementieren Sie den ADT Queue mit Hilfe einer verketteten Liste ohne einen Dummy- Knoten zu verwenden.. Übung

Implementieren Sie eine Zahlenmenge mit Hilfe einer linearen Liste (Hinweise: Ein Menge enthält niemals mehrere Exemplare der

kum die Situation in Deutschland, wenn er behauptet, daß es in jeder besseren deutschen Schule ein Exemplar gebe.2 Dazu paßt, daß es Millin gleichzeitig nicht gelang, die Bände

Unter erwachsenen Personen mit chronischen Krankheiten sollen die mit dem höchsten Risiko für einen schweren Verlauf von Covid-19 prioritär Zugang zur Impfung erhalten..

struct dolili *elem_ptr = NULL; // Erzeugen eines Zeigers auf ein Element der Liste Damit Sie dynamisch neue Elemente einer Liste hinzufügen können, müssen Sie einen Teil des

Und dieses Prinzip soll auch noch funktionieren, wenn wir ein Programm haben, das ein paar Gigabyte Platz ben¨otigt und es tausende von freien Bl¨ocken gibt, die aber sehr klein

Dis- kussionen um eine Erweiterung der Negativliste hält Frau Adam- Schwaetzer freilich nicht für gera- ten, jedenfalls nicht vor 1984.. Fazit also zur Negativliste: Das Ding

Auswahl an Geräten siehe Homepage Eastek systems GmbH Kundenzähler Counteasy wireless Set V3 bidirektional:. &gt; keine Leitungsverlegung notwendig, System arbeitet auf