Diskuze: v C# triedenie
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.

Člen

Zobrazeno 19 zpráv z 19.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Test znalostí C# .NET online, jsme si ověřili nabyté zkušenosti z kurzu.
Vzestupně:
Slovicka.Sort();
Sestupně:
Slovicka.Sort();
Slovicka.Reverse();
Vzestupně:
Slovicka = Slovicka.OrderBy(s => s).ToList();
Sestupně:
Slovicka = Slovicka.OrderByDescending(s => s).ToList();
Dik. A ked to chcem zotriedit podla dlzok slov, mam vytvorit pole dlzky?
Slovicka = Slovicka.OrderBy(x => x.Length).ToList(); // od nejkratšího
Slovicka = Slovicka.OrderByDescending(x => x.Length).ToList(); // od nejdelšího
Na vložení kódu je tu i tlačítko..
Dik. Ako mám upraviť program aby mi to vypisalo v takomto tvare: auto 4 car 3
Dá sa v takto zotriedenom poli podľa dlžky reťazca vyhľadať najmenší alebo stredný prvok?
Pokud to chceš vypisovat v uvedeném tvaru, tak ti seřazaní bude k ničemu, když chceš mít překlady vedle sebe. Můžeš si to vypsat v tom tvaru, který chceš, třeba takhle:
for (int i = 0; i < Slovicka.Count; i++ )
{
Console.WriteLine(Slovicka[i] + " " + Slovicka[i].Length + " " + Slovicka1[i] + " " + Slovicka1[i].Length);
}
Přičemž teda vycházím z faktu, že obě slovní kolekce mají stejný
počet prvků.
Pokud bys provedl setřídění prvků podle délky, tak ten
nejdelší/nejkraší najdeš vždy pod indexem 0 (podle toho jestli jsi to
třídil vzestupně nebo ne), střední hodnotu pak pod indexem
Slovicka.Count/2. Jinak teda je možná zbytečné si dělat dva Listy, klidně
by stačil jeden, který by měl dva stringy, tím bys měl slovo a překlad
vždy u sebe. Jo a btw nepracuješ s polem, ale s listem.
Dakujem. Ešte by som sa chcela spýtať, ak by som chcela ukončiť zadavanie slov nie tak ako mám "koniec" ale stlačením napr. klávesu K, ako by som to mohla zadať. Dik
Jak si to přesně představuješ? Žeby uživatel zadával slova a najednou by nějaké slovo obsahovalo
písmeno K a zadávání by se zastavilo? To mě nepřijde jako štastné
řešení, když slova mohou obsahovat písmeno K.
No napríklad ukonči zadavanie slov stlačením klávesu ESC. Alebo zobraz zotriedene údaje stlačením klávesu T. Neviem ako to mám naprogramovať. Niečo som si našla v knihe ale nejde mi to. Dik
Tak to vy stačilo ten cyklus předělat takto:
while (true)
{
Console.WriteLine("Zadaj slova a ich preklad vo formate slovo:slovo.");
if (Console.ReadKey(true).Key == ConsoleKey.Escape)
break;
string prikaz = Console.ReadLine();
var riadok = prikaz.Split(Convert.ToChar(":"));
Slovicka.Add(riadok[0]);
Slovicka1.Add(riadok[1]);
}
V podstatě jen před zadáváním další hodnoty kontroluju vstup z
klávesnice, pokud někdo klikne ESC, tak se cyklus zastaví a dojde k
vyhodnocení.. pokud bys to chtěla na písmeno, tak jen přepíšeš konec
podmínky na ConsoleKey.T a taky jsem z kódu vymazal dva řádky, to string[]
slovo = Slovicka.ToArray(); a string[] slovo1 = Slovicka1.ToArray(); protože
nepracuješ s polem, ale listem a tahle pole nikde nepoužíváš.
Ak chcem vypisať napr. najkratšie slovenske slovo alebo najdlhsie pouzijem BinarySearch?
Jestli je kolecke seřazená, tak najdeš tyto prvky pod extension metdama First() a Last(). Jestli kolecke seřazená není, můžeš použít zase extension metody Min(s => s.Length) nebo Max(s => s.Length)
Ok idem to vyskušať. Mam tu ešte jeden algoritmus na triedenie a
vyhľadavanie, podari sa mi zotriediť len mi tam medzi tým vypisuje nejaké
hlaseniaa System int32, prečo?
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace ConsoleApplication1
{
class Program
{
static void Main(string[] args)
{
List<int> numbers = new List<int>();
while (true)
{
Console.WriteLine("Zadaj číslo a ukonci zadavanie stlacenim klavesu ESC ");
// zadavanie nahodnzch cisiel a konci sa stlacenim klavesu ESC
if (Console.ReadKey(true).Key == ConsoleKey.Escape)
{
break;
}
numbers.Add(int.Parse(Console.ReadLine()));
}
int[] pole = numbers.ToArray();//naplnenie pola udajmi
Console.WriteLine("Pole pred zotriedenim" + pole );
vypispole(pole); // volanie vypisu pola
selectionSort(pole); // volanie triedenia
vyhladaj(pole);
}
public static void selectionSort(int[] pole)
{
int pomocna, min;
for (int i = 0; i < (pole.Length - 1); i++)
{
min = pole.Length - 1;
for (int j = i; j < (pole.Length - 1); j++)
{
if ((pole[min] > pole[j]))
min = j;
}
pomocna = pole[min];
pole[min] = pole[i];
pole[i] = pomocna;
Console.WriteLine("Pole po zotriedeni");
Console.WriteLine(string.Join(", ", pole));
vypispole(pole);
Console.ReadKey();
}
}
public static void vypispole(int[] pole)
{
for (int i = 0; i < pole.Length; i++)
{
Console.WriteLine(pole);
}
}
public static void vyhladaj(int[] pole)
{
int x = 2;
int j = Array.BinarySearch(pole, x);
if (j >= 0)
System.Console.WriteLine("hodnota {0} má index {1}", x, j);
else if ((j = ~j) == pole.GetLength(0))
System.Console.WriteLine("hodnota {0} je větší než všechny prvky pole",
x);
else
System.Console.WriteLine("hodnota {0} patří před {1}. prvek", x, j);
}
}
}
Slovicka[Slovicka.Count/2]
Ale jen V seřazeném poli ofc.
Zobrazeno 19 zpráv z 19.