Commit 5f1bb3b0 authored by Uwe Wienkop's avatar Uwe Wienkop

2020-05-05

parent 05844781
using System;
using System.Collections;
using System.Security.Cryptography;
namespace _02VerketteteListe_2
{
......@@ -17,11 +18,12 @@ namespace _02VerketteteListe_2
}
Element anf = null, ende = null;
// int anz=0;
int anz = 0; // Sehr sinnvoll für Index-Ops
//public StringListe() { }
public void AddEnd(string name)
{
Element neuesElement = new Element(name); // 1. Neues Element anlegen
anz++;
if (anf == null) // 2. Leere Liste?
anf = ende = neuesElement;
else
......@@ -35,6 +37,7 @@ namespace _02VerketteteListe_2
// 1. Leere Liste
// 2. Es existiert mind. ein Element
Element neuesElement = new Element(name); // Neues Element anlegen
anz++;
if (anf == null) // 1.Fall: Leere Liste?
anf = ende = neuesElement;
else
......@@ -69,25 +72,27 @@ namespace _02VerketteteListe_2
// an der gespeicherten Pos. weitergemacht.
}
}
public void DeleteFront()
public void DeleteFirst()
{
// 1.Fall: Liste ist leer
// 2.Fall: Liste besteht nur aus einem Element
// 3.Fall: Liste hat mehr als ein Element
if (anf == null) // 1. Fall
return;
anz--;
if (anf == ende) // 2. Fall
anf = ende = null;
else
anf = anf.next; // 3. Fall
}
public void DeleteEnd()
public void DeleteLast()
{
// 1.Fall: Liste ist leer
// 2.Fall: Liste besteht nur aus einem Element
// 3.Fall: Liste hat mehr als ein Element
if (anf == null) // 1. Fall
throw new NullReferenceException("Die Liste ist leer");
anz--;
if (anf == ende) // 2. Fall
anf = ende = null;
else // 3. Fall
......@@ -100,27 +105,114 @@ namespace _02VerketteteListe_2
ende = vorletzter;
}
}
public void DeleteNth(int Ind)
public void DeleteNth(int index)
{
// 1.Fall: Liste ist leer
// 2.Fall: Liste besteht nur aus einem Element UND Ind == 0
// 3.Fall: Liste hat mehr als ein Element
// a) Ind==0 --> DeleteFront()
// b) Ind==max -> DeleteLast()
// c) Ind < max
if (anf == null) // 1. Fall
throw new NullReferenceException("Die Liste ist leer");
if (anf == ende) // 2. Fall
anf = ende = null;
else // 3. Fall
{ // Wir wissen: Die Liste hat mehr als ein Element, d.h. es gibt ein
// vorletztes Element vorletzter.next == ende
// 1.Fall: Liste ist leer ODER Ind>=anz --> Fehler
// 2.Fall: Ind == 0 --> DeleteFirst
// 3.Fall: Ind == anz-1 --> DeleteLast
// 4. Bis hierher: Liste hat mind. ein Element und das zu löschende Element
// ist nicht das Erste oder Letzte
if (anz == 0 || index >= anz) // 1. Fall
throw new ArgumentOutOfRangeException("Außerhalb der Anzahl der Listenelemente");
if (index == 0) // 2. Fall
DeleteFirst();
else if (index == anz - 1) // 3. Fall
DeleteLast();
else
{
Element vorletzter = anf;
while (vorletzter.next != ende)
for (int i = 1; i < index; i++)
vorletzter = vorletzter.next;
vorletzter.next = null;
ende = vorletzter;
vorletzter.next = vorletzter.next.next;
anz--;
}
}
public void DeleteByName(string name)
{
// leere Liste ohne Elemente
if (anf == null)
return;
// erstes Element = gesuchtes Element
if (anf.name.CompareTo(name) == 0)
DeleteFirst();
// Wir wissen jetzt:
// Liste hat mind. ein Element UND das erste Element ist nicht das gesuchte Element
else
{
Element item = anf;
// Durchlaufen der Liste
// solange Elemente in Liste vorhanden und gesuchtes Element noch nicht gefunden
while (item.next != null && item.next.name.CompareTo(name) != 0)
item = item.next;
// Wenn gesuchtes Element in Liste vorhanden
if (item.next != null)
{
// Nächstes Element überspringen = löschen
item.next = item.next.next;
// Wenn letztes Element = gesuchtes Element
if (item.next == null)
ende = item;
}
}
}
public void AddBeforeNth(int index, string name)
{
if (index < 0 || index > anz)
throw new ArgumentOutOfRangeException("Index außerhalb der Listengröße");
if (index == 0)
AddFront(name);
else if (index == anz)
AddEnd(name);
else
{
Element neu = new Element(name);
anz++;
Element item = anf;
for (int i = 1; i < index; i++)
item = item.next;
neu.next = item.next;
item.next = neu;
}
}
public void AddSorted(string name)
{
// 1. Fall: Leere Liste oder Anfügen am Listenende
if (anf == null || ende.name.CompareTo(name) <= 0)
AddEnd(name);
else
{
if (name.CompareTo(anf.name) <= 0)
AddFront(name);
else
{
Element neu = new Element(name);
anz++;
Element item = anf;
while (item.next.name.CompareTo(name) < 0)
item = item.next;
neu.next = item.next;
item.next = neu;
}
}
}
private Element NthElem(int index)
{
if (index < 0 || index >= anz)
throw new IndexOutOfRangeException("Listenindex außerhalb des gültigen Bereichs");
Element item = anf;
while (index > 0)
{
item = item.next;
index--;
}
return item;
}
public string this[int index]
{
get => NthElem(index).name;
set { NthElem(index).name = value; }
}
}
class Program
......@@ -130,29 +222,12 @@ namespace _02VerketteteListe_2
StringListe l1 = new StringListe();
StringListe l2 = new StringListe();
//StringListe.Element e1 = new StringListe.Element("Anton");
//e1.next = null;
for (int i = 1; i <=3; i++)
{
l1.AddEnd("Name-" + i);
}
foreach (string item in l1)
{
Console.WriteLine($"foreach: {item}");
}
//Console.WriteLine( l1.Print2());
Console.WriteLine("==========");
l1.DeleteEnd();
l1.Print();
Console.WriteLine("----------");
l1.DeleteEnd();
l1.AddSorted("Emil ");
l1.AddSorted("Anton");
l1.AddSorted("Berta");
l1.AddSorted("Claudia");
l1.AddSorted("Dieter");
l1.Print();
Console.WriteLine("----------");
//l1.LoescheAnf();
//l1.Print();
//Console.WriteLine($"Suche nach Name-3: {l1.Suche("Name-3")}");
}
}
}
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
<OutputType>Exe</OutputType>
<TargetFramework>netcoreapp3.1</TargetFramework>
<RootNamespace>_03_UebgDi_ZyklischeListe</RootNamespace>
</PropertyGroup>
</Project>
using System;
namespace _03_UebgDi_ZyklischeListe
{
class CycleList
{
class Element
{
public string name;
public Element next = null;
public Element(string name) { this.name = name; }
public override string ToString() => name;
}
Element anf = null, ende = null;
Element iterator = null;
public void AddEnd(string name)
{
Element neuesElement = new Element(name); // 1. Neues Element anlegen
if (anf == null) // 2. Leere Liste?
anf = ende = neuesElement;
else
ende = ende.next = neuesElement; // 3. Neues Element am Ende anfügen
}
public void CloseCycle()
{
ende.next = anf;
}
public void Print()
{
}
public void SetIterator(int plus)
{
}
public string GetName() => ;
public void MoveIterator() { }
}
class Program
{
static void Main(string[] args)
{
CycleList cl = new CycleList();
cl.AddEnd("Anton");
cl.AddEnd("Berta");
cl.CloseCycle();
cl.Print();
Console.WriteLine("-------------");
cl.AddEnd("Claudia");
cl.AddEnd("Dieter");
cl.CloseCycle();
cl.Print();
Console.WriteLine("-------------");
//cl.SetIterator(2);
//for (int i = 0; i < 10; i++)
//{
// Console.WriteLine(cl.GetName());
// cl.MoveIterator();
//}
}
}
}
{
"runtimeTarget": {
"name": ".NETCoreApp,Version=v3.1",
"signature": ""
},
"compilationOptions": {},
"targets": {
".NETCoreApp,Version=v3.1": {
"03 UebgDi ZyklischeListe/1.0.0": {
"runtime": {
"03 UebgDi ZyklischeListe.dll": {}
}
}
}
},
"libraries": {
"03 UebgDi ZyklischeListe/1.0.0": {
"type": "project",
"serviceable": false,
"sha512": ""
}
}
}
\ No newline at end of file
{
"runtimeOptions": {
"additionalProbingPaths": [
"C:\\Users\\wienkop\\.dotnet\\store\\|arch|\\|tfm|",
"C:\\Users\\wienkop\\.nuget\\packages"
]
}
}
\ No newline at end of file
{
"runtimeOptions": {
"tfm": "netcoreapp3.1",
"framework": {
"name": "Microsoft.NETCore.App",
"version": "3.1.0"
}
}
}
\ No newline at end of file
{
"format": 1,
"restore": {
"C:\\Users\\wienkop\\source\\repos\\prog2-ss2020-wienkop\\03 UebgDi ZyklischeListe\\03 UebgDi ZyklischeListe.csproj": {}
},
"projects": {
"C:\\Users\\wienkop\\source\\repos\\prog2-ss2020-wienkop\\03 UebgDi ZyklischeListe\\03 UebgDi ZyklischeListe.csproj": {
"version": "1.0.0",
"restore": {
"projectUniqueName": "C:\\Users\\wienkop\\source\\repos\\prog2-ss2020-wienkop\\03 UebgDi ZyklischeListe\\03 UebgDi ZyklischeListe.csproj",
"projectName": "03 UebgDi ZyklischeListe",
"projectPath": "C:\\Users\\wienkop\\source\\repos\\prog2-ss2020-wienkop\\03 UebgDi ZyklischeListe\\03 UebgDi ZyklischeListe.csproj",
"packagesPath": "C:\\Users\\wienkop\\.nuget\\packages\\",
"outputPath": "C:\\Users\\wienkop\\source\\repos\\prog2-ss2020-wienkop\\03 UebgDi ZyklischeListe\\obj\\",
"projectStyle": "PackageReference",
"configFilePaths": [
"C:\\Users\\wienkop\\AppData\\Roaming\\NuGet\\NuGet.Config",
"C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config"
],
"originalTargetFrameworks": [
"netcoreapp3.1"
],
"sources": {
"C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {},
"https://api.nuget.org/v3/index.json": {}
},
"frameworks": {
"netcoreapp3.1": {
"projectReferences": {}
}
},
"warningProperties": {
"warnAsError": [
"NU1605"
]
}
},
"frameworks": {
"netcoreapp3.1": {
"imports": [
"net461",
"net462",
"net47",
"net471",
"net472",
"net48"
],
"assetTargetFallback": true,
"warn": true,
"frameworkReferences": {
"Microsoft.NETCore.App": {
"privateAssets": "all"
}
},
"runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\3.1.201\\RuntimeIdentifierGraph.json"
}
}
}
}
}
\ No newline at end of file
<?xml version="1.0" encoding="utf-8" standalone="no"?>
<Project ToolsVersion="14.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup Condition=" '$(ExcludeRestorePackageImports)' != 'true' ">
<RestoreSuccess Condition=" '$(RestoreSuccess)' == '' ">True</RestoreSuccess>
<RestoreTool Condition=" '$(RestoreTool)' == '' ">NuGet</RestoreTool>
<ProjectAssetsFile Condition=" '$(ProjectAssetsFile)' == '' ">$(MSBuildThisFileDirectory)project.assets.json</ProjectAssetsFile>
<NuGetPackageRoot Condition=" '$(NuGetPackageRoot)' == '' ">$(UserProfile)\.nuget\packages\</NuGetPackageRoot>
<NuGetPackageFolders Condition=" '$(NuGetPackageFolders)' == '' ">C:\Users\wienkop\.nuget\packages\</NuGetPackageFolders>
<NuGetProjectStyle Condition=" '$(NuGetProjectStyle)' == '' ">PackageReference</NuGetProjectStyle>
<NuGetToolVersion Condition=" '$(NuGetToolVersion)' == '' ">5.5.0</NuGetToolVersion>
</PropertyGroup>
<PropertyGroup>
<MSBuildAllProjects>$(MSBuildAllProjects);$(MSBuildThisFileFullPath)</MSBuildAllProjects>
</PropertyGroup>
</Project>
\ No newline at end of file
<?xml version="1.0" encoding="utf-8" standalone="no"?>
<Project ToolsVersion="14.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
<PropertyGroup>
<MSBuildAllProjects>$(MSBuildAllProjects);$(MSBuildThisFileFullPath)</MSBuildAllProjects>
</PropertyGroup>
</Project>
\ No newline at end of file
//------------------------------------------------------------------------------
// <auto-generated>
// Dieser Code wurde von einem Tool generiert.
// Laufzeitversion:4.0.30319.42000
//
// Änderungen an dieser Datei können falsches Verhalten verursachen und gehen verloren, wenn
// der Code erneut generiert wird.
// </auto-generated>
//------------------------------------------------------------------------------
using System;
using System.Reflection;
[assembly: System.Reflection.AssemblyCompanyAttribute("03 UebgDi ZyklischeListe")]
[assembly: System.Reflection.AssemblyConfigurationAttribute("Debug")]
[assembly: System.Reflection.AssemblyFileVersionAttribute("1.0.0.0")]
[assembly: System.Reflection.AssemblyInformationalVersionAttribute("1.0.0")]
[assembly: System.Reflection.AssemblyProductAttribute("03 UebgDi ZyklischeListe")]
[assembly: System.Reflection.AssemblyTitleAttribute("03 UebgDi ZyklischeListe")]
[assembly: System.Reflection.AssemblyVersionAttribute("1.0.0.0")]
// Von der MSBuild WriteCodeFragment-Klasse generiert.
C:\Users\wienkop\source\repos\prog2-ss2020-wienkop\03 UebgDi ZyklischeListe\bin\Debug\netcoreapp3.1\03 UebgDi ZyklischeListe.exe
C:\Users\wienkop\source\repos\prog2-ss2020-wienkop\03 UebgDi ZyklischeListe\bin\Debug\netcoreapp3.1\03 UebgDi ZyklischeListe.deps.json
C:\Users\wienkop\source\repos\prog2-ss2020-wienkop\03 UebgDi ZyklischeListe\bin\Debug\netcoreapp3.1\03 UebgDi ZyklischeListe.runtimeconfig.json
C:\Users\wienkop\source\repos\prog2-ss2020-wienkop\03 UebgDi ZyklischeListe\bin\Debug\netcoreapp3.1\03 UebgDi ZyklischeListe.runtimeconfig.dev.json
C:\Users\wienkop\source\repos\prog2-ss2020-wienkop\03 UebgDi ZyklischeListe\bin\Debug\netcoreapp3.1\03 UebgDi ZyklischeListe.dll
C:\Users\wienkop\source\repos\prog2-ss2020-wienkop\03 UebgDi ZyklischeListe\bin\Debug\netcoreapp3.1\03 UebgDi ZyklischeListe.pdb
C:\Users\wienkop\source\repos\prog2-ss2020-wienkop\03 UebgDi ZyklischeListe\obj\Debug\netcoreapp3.1\03 UebgDi ZyklischeListe.csproj.CoreCompileInputs.cache
C:\Users\wienkop\source\repos\prog2-ss2020-wienkop\03 UebgDi ZyklischeListe\obj\Debug\netcoreapp3.1\03 UebgDi ZyklischeListe.AssemblyInfoInputs.cache
C:\Users\wienkop\source\repos\prog2-ss2020-wienkop\03 UebgDi ZyklischeListe\obj\Debug\netcoreapp3.1\03 UebgDi ZyklischeListe.AssemblyInfo.cs
C:\Users\wienkop\source\repos\prog2-ss2020-wienkop\03 UebgDi ZyklischeListe\obj\Debug\netcoreapp3.1\03 UebgDi ZyklischeListe.dll
C:\Users\wienkop\source\repos\prog2-ss2020-wienkop\03 UebgDi ZyklischeListe\obj\Debug\netcoreapp3.1\03 UebgDi ZyklischeListe.pdb
C:\Users\wienkop\source\repos\prog2-ss2020-wienkop\03 UebgDi ZyklischeListe\obj\Debug\netcoreapp3.1\03 UebgDi ZyklischeListe.genruntimeconfig.cache
{
"version": 3,
"targets": {
".NETCoreApp,Version=v3.1": {}
},
"libraries": {},
"projectFileDependencyGroups": {
".NETCoreApp,Version=v3.1": []
},
"packageFolders": {
"C:\\Users\\wienkop\\.nuget\\packages\\": {}
},
"project": {
"version": "1.0.0",
"restore": {
"projectUniqueName": "C:\\Users\\wienkop\\source\\repos\\prog2-ss2020-wienkop\\03 UebgDi ZyklischeListe\\03 UebgDi ZyklischeListe.csproj",
"projectName": "03 UebgDi ZyklischeListe",
"projectPath": "C:\\Users\\wienkop\\source\\repos\\prog2-ss2020-wienkop\\03 UebgDi ZyklischeListe\\03 UebgDi ZyklischeListe.csproj",
"packagesPath": "C:\\Users\\wienkop\\.nuget\\packages\\",
"outputPath": "C:\\Users\\wienkop\\source\\repos\\prog2-ss2020-wienkop\\03 UebgDi ZyklischeListe\\obj\\",
"projectStyle": "PackageReference",
"configFilePaths": [
"C:\\Users\\wienkop\\AppData\\Roaming\\NuGet\\NuGet.Config",
"C:\\Program Files (x86)\\NuGet\\Config\\Microsoft.VisualStudio.Offline.config"
],
"originalTargetFrameworks": [
"netcoreapp3.1"
],
"sources": {
"C:\\Program Files (x86)\\Microsoft SDKs\\NuGetPackages\\": {},
"https://api.nuget.org/v3/index.json": {}
},
"frameworks": {
"netcoreapp3.1": {
"projectReferences": {}
}
},
"warningProperties": {
"warnAsError": [
"NU1605"
]
}
},
"frameworks": {
"netcoreapp3.1": {
"imports": [
"net461",
"net462",
"net47",
"net471",
"net472",
"net48"
],
"assetTargetFallback": true,
"warn": true,
"frameworkReferences": {
"Microsoft.NETCore.App": {
"privateAssets": "all"
}
},
"runtimeIdentifierGraphPath": "C:\\Program Files\\dotnet\\sdk\\3.1.201\\RuntimeIdentifierGraph.json"
}
}
}
}
\ No newline at end of file
{
"version": 2,
"dgSpecHash": "qRFuevN0NLacVpvhFL3OmJHqG/WV9IVxq3C9wQceX3LcC1W/HAbGolztAyonQA4Sc2wSfh+9Gzf3WsXthTN9aA==",
"success": true,
"projectFilePath": "C:\\Users\\wienkop\\source\\repos\\prog2-ss2020-wienkop\\03 UebgDi ZyklischeListe\\03 UebgDi ZyklischeListe.csproj",
"expectedPackageFiles": [],
"logs": []
}
\ No newline at end of file