Uživatelské nástroje

Nástroje pro tento web


pitel:tin:ukoly:2011:4

Úkol 4

Bc. Jan Kaláb <xkalab00@stud.fit.vutbr.cz>

Příklad 1

Pomocí počátečních funkcí, a operátorů kombinace, kompozice a primitivní rekurze výjádřete funkci počítající zbytek po celočíselném dělení:

mod: ℕ² → ℕ, mod(x, y) = z takové, že x = y * k + z pro nějaké k ∈ ℕ.

Je možné použít funkce plus(x, y) a mult(x, y) definované v přednáškách, kromě nich nepoužívejte žádné další funkce zavedené na přednáškách mimo funkce počáteční. Nepoužívejte zjednodušenou syntaxi zápisu funkcí – dodržte přesně definiční tvar operátorů kombinace, kompozice a primitivní rekurze.

  • pred(0) = ξ()
  • pred(x + 1) = π²₁(x × pred(x)))
  • monus(x, 0) = π¹₁(x)
  • monus(x, y + 1) = predmonus(x, y)
  • minmonus ∘ (π²₁ × (monus ∘ (π²₁ × π²₂)))
  • sgmin ∘ ((σξ()) × π¹₁)
  • gtsgmonus ∘ (π²₁ × π²₂)
  • mod(x, 0) = FAIL
  • mod(0, y) = 0
  • mod(x + 1, y) = plus ∘ (mod(x, y) × (gt ∘ (y × (σmod(x, y)))))1)

Příklad 2

Mějme danou primitivně rekurzivní funkci crypt: ℕ → ℕ, která pro daný vstup (zakódovaný jako přirozené číslo) vrátí jeho zašifrovanou podobu (opět zakódovanou jako přirozené číslo).

Navrhněte parciálně rekurzivní funkci decrypt: ℕ → ℕ takovou, že ∀n ∈ ℕ. decryptcrypt(n) = n. Můžete použít zjednodušenou formu zápisu funkcí.

Pozn.: O vlastním fungování funkce crypt nemáte k dispozici žádné další informace. V případě, že existují x, y ∈ ℕ takové, že xycrypt(x) = crypt(y), pak výsledkem decryptcrypt(x) může být x, nebo y.

decrypt(x) = μyeq(crypt(y), x) = 0]

Příklad 3

Mějme následující funkce:

  • f(n) = sqrt(2)n³
  • g(n) = 10000n² + 500n + 211

Dokažte, že O(g(n)) ⊂ O(f(n)).

Pozn.: Nezapomeňte, že důkaz má dvě části: (i) O(g(n)) ⊆ O(f(n)) a (ii) O(g(n)) ≠ O(f(n))

sqrt(2)n³ = 10000n² + 500n + 211
n = 7071,12

  1. Z grafu funkcí a výsledku rovnice je zřejmé, že od n = 7072 je g(n) < f(n). A protože obě funkce mají stejný definiční obor (ℕ) můžeme tvrdit že O(g(n)) ⊆ O(f(n)).
  2. Protože výsledkem rovnice je pouze jeden kořen, je navíc zřejmé, že od n = 7072 se funkce nikde jinde nerovnají (neprotínají), a tudíž O(g(n)) ≠ O(f(n)).

Tedy O(g(n)) ⊂ O(f(n)).

Příklad 4

Tři kamarádi se rozhodli navštívit autem všechny obce v jednom regionu. Rádi by svoji cestu naplánovali tak, aby každou obec navštívili právě jednou (průjezd obcí se počítá jako její návštěva). Pro zjednodušení předpokládejme, že křižovatky silnic jsou pouze uvnitř obcí.

Dokažte redukcí z nějakého známého NP-těžkého problému, že problém existence vhodné trasy je NP-těžký.

Nápověda: Zvlášť vhodný je jeden z níže uvedených problémů:

Z nabízených problémů je zvlášť vhodný problém existence Hamiltonské kružnice v neorientovaném grafu. Problém Výlet tedy redukujeme na problém Hamilton takto:

  • Jako uzly grafu zakódujeme města
  • Jako hrany zakódujeme silnice mezi městy

Nyní je zřejmé, že problém Hamilton je ekvivalentní problému Výlet. A protože víme, že problém Hamilton je NP úplný, je problém výlet NP těžký.

1)
mod(x, y) + (y > (mod(x, y) + 1))
/var/www/wiki/data/pages/pitel/tin/ukoly/2011/4.txt · Poslední úprava: 30. 12. 2022, 13.43:01 autor: 127.0.0.1