联系方式

  • QQ:99515681
  • 邮箱:99515681@qq.com
  • 工作时间:8:00-21:00
  • 微信:codinghelp

您当前位置:首页 >> Python编程Python编程

日期:2020-03-24 11:10

CSC2047/Assignment 2 (v1)

1. Decide whether each of the following expressions are true or not. Answer yes or no.

Hint: Remember that e.g. 4n = O(n2) is true, even though 4n = O(n) is also the case.

In any case where it is not true, perform an asymptotic analysis using the informal method

discussed in the lecture so as to provide a correct O-complexity (that is, do not provide an Ocomplexity

which is unnecessarily high; e.g. for 4n, O(n) would be fine, however O(n

2) would not).

2. Consider the language

L = {hG, ni | G is an undirected graph with n connected components}.

Consider the following undirected graphs:

(a) For each of the following statements, decide whether it holds.

(i) hG1, 1i ∈ L [1 mark]

(ii) hG2, 2i ∈ L [1 mark]

(iii) hG3, 1i ∈ L [1 mark]

(iv) hG3, 4i ∈ L [1 mark]

(v) hG4, 3i ∈ L [1 mark]

(vi) hG4, 4i ∈ L [1 mark]

(b) Prove that L is decidable by providing a high-level decider. (That is, an algorithm-like

description in English, cf. the according lecture slides) Your implementation should require

no more than polynomial time. [2 marks]

(c) Argue that your decider runs in polynomial time. Do so by reasoning about the runtime of

its individual steps, the number of steps required, etc. as in the lecture. [2 marks]

Page 3 of 9

CSC2047/Assignment 2 (v1)

3. Consider the following Turing machine M with input alphabet Σ = {0, 1, #}:

(a) Let C1 be the initial configuration for the input word #101 and let C2 be the configuration

yielded by C2. That is, C2 is the configuration obtained from the Turing machine after one

step when it is started on the word #101.

(i) Provide C1 in terms of a string [1 mark]

(ii) Provide C2 in terms of a string [1 mark]

(b) Decide whether each of the following strings would be accepted by the Turing machine.

Write down the computation the Turing machine performs for each of them in terms of a

sequence of configurations. For the accepted ones, answer yes; otherwise, no.

(i) # [1 mark]

(ii) ## [1 mark]

(iii) 0 [1 mark]

(iv) #0 [1 mark]

(v) #1 [1 mark]

(vi) #00 [1 mark]

(vii) #01 [1 mark]

(viii) #10 [1 mark]

(ix) #11 [1 mark]

(x) #101 [1 mark]

(c) What is the language of accepted (input) words of this Turing machine? Describe the

language using a regular expression. [1 mark]

(d) What is the language of (output) words which may be on the tape at the moment the

Turing machine has moved to the accepting state? Describe the language using a regular

expression. [1 mark]

(e) What is the worst-case runtime f(n) of this Turing machine for a word of length n? [2 marks]

(f) What is the best-case runtime g(n) of this Turing machine for a word of length n? [2 marks]

(g) Formalise the graphical representation of the Turing machine above as a 7-tuple. [2 marks]

Page 4 of 9

CSC2047/Assignment 2 (v1)

4. Consider the following three-tape Turing machine with input alphabet Σ = {a, b, c}:

a, ␣, ␣→(a, N),(a, R),(a, R) a, ␣, ␣ → (a, N),(a, R),(a, R)

a, ␣, ␣ → (a, R),(a, R),(␣, N)

b, ␣, ␣ → (b, N),(␣, N),(␣, N)

b, a, ␣ → (b, R),(␣, N),(␣, N)

b, ␣, ␣ → (b, N),(␣, L),(␣, N)

c, ␣, ␣ → (c, N),(␣, N),(␣, N)

c, ␣, a → (c, R),(␣, N),(␣, N)

c, ␣, ␣ → (c, N),(␣, N),(␣, L)

␣, ␣, ␣

→ (␣, N),(␣, L),(␣, L) ␣, ␣, ␣

→ (␣, N),(␣, L),(␣, L)

␣, ␣, ␣

→ (␣, N),(␣, N),(␣, N)

(a) Decide whether each of the following strings would be accepted by the Turing machine.

Write down the computation the Turing machine performs for each of them in terms of a

sequence of configurations. For the accepted ones, answer yes; otherwise, no.

(i) ε [1 mark]

(ii) abc [1 mark]

(iii) abbbcc [1 mark]

(iv) abbb [1 mark]

(v) bac [1 mark]

(vi) aabbbbbbcccc [1 mark]

(b) Which language does this machine recognise? Provide the language in set notation.

[2 marks]

(c) Provide a two-tape Turing machine which recognises the same language and still runs in

the same runtime order O(n). [2 marks]

Page 5 of 9

CSC2047/Assignment 2 (v1)

5. Consider the following nondeterministic Turing machine with input alphabet Σ = {0, 1}:

(a) Decide whether each of the following strings would be accepted by the Turing machine.

Write down a computation the Turing machine performs for each of them in terms of a

sequence of configurations. For the accepted ones, the computation you write down should

be an accepting computation. For the accepted ones, answer yes; otherwise, no.

(i) ε [1 mark]

(ii) 0 [1 mark]

(iii) 1 [1 mark]

(iv) 01 [1 mark]

(v) 10 [1 mark]

(vi) 101 [1 mark]

(vii) 11100 [1 mark]

(viii) 10100 [1 mark]

(b) What is the language of accepted words of this Turing machine? Describe the language

using a regular expression. [2 marks]

(c) What is the worst-case runtime f(n) of this Turing machine for a word of length n? Remember

that you have to consider the maximum over all possible runs for the word. [2 marks]

(d) What is the best-case runtime g(n) of this Turing machine for a word of length n? Remember

that you have to consider the maximum (not the minimum) over all possible runs

for the word. [2 marks]

(e) What is the maximum number of different runs for a given word of length n? [1 mark]

(f) What is the minimum number of different runs for a given word of length n > 0? [1 mark]

(g) Provide a (deterministic) Turing machine which always halts which recognises the same

language as this nondeterministic Turing machine. [2 marks]

(h) Formalise the graphical representation of the nondeterministic Turing machine above as a

7-tuple. [2 marks]

Page 6 of 9

CSC2047/Assignment 2 (v1)

6. Consider the language

HAMPATH = {hG, s, ti | G is a directed graph with a Hamiltonian path from s to t}

HAMPATH can be reduced to SAT as follows: Consider an arbitrary directed graph G = (V, E)

with n vertices and m edges. We assume V = {v1, . . . , vn}. We consider the set of variables

C = {ci,j | 1 ≤ i ≤ n and 1 ≤ j ≤ n}.

Consider formula φ consisting of the conjunction (∧) of the following set S of clauses:

S = Satleastonce ∪ Smaxoneperstage ∪ Snottwice ∪ Sfirst ∪ Slast ∪ Spath

where

• Satleastonce = {(ci,1 ∨ . . . ∨ ci,n) | 1 ≤ i ≤ n},

• Smaxoneperstage = {ci,k ∨ cj,k | 1 ≤ i ≤ n and 1 ≤ j ≤ n and i < j and 1 ≤ k ≤ n}

• Snottwice = {(ck,i ∨ ck,j ) | 1 ≤ k ≤ n and 1 ≤ i ≤ n and 1 ≤ j ≤ n and i < j},

• Sfirst = {ci,1} where vi = s,

• Slast = {ci,n} where vi = t,

• Spath = {ci,k ∨ cj,k+1 | (vi

, vj ) ∈/ E and 1 ≤ i ≤ n and 1 ≤ j ≤ n and 1 ≤ k ≤

n − 1 and i 6= j}.

For instance, if we consider the set A = {a ∨ b, c, c ∨ a}, then the conjunction of the clauses of

A would be φ = (a ∨ b) ∧ c ∧ (c ∨ a), where the order of clauses in φ is arbitrary. The way the

encoding works is similar to how the nondeterministic decider N1 from “Time Complexity - Part

3” recognises HAMPATH . A variable ci,k encodes the fact that that node vi

is chosen as the

k-th number (pk in the algorithm). Satleastonce ensures that each node is chosen at least once.

Accordingly, Snottwice ensures that each node is chosen no more than once: if vk it is chosen as

the i-th number, then it cannot be chosen again as later number j. Sfirst and Slast ensure that

s and t are the first and last nodes of the path to be obtained. Spath encodes step 4. of the

algorithm seen in the lecture: it disallows that a node vi

is followed by node vj

if there is no edge

from the first to the second node.

(a) Consider the following directed graphs:

Encode the following problems into Boolean formulas as described above.

(i) hG1, v1, v2i ∈ HAMPATH [1 mark]

(ii) hG2, v1, v3i ∈ HAMPATH [1 mark]

(iii) hG3, v1, v4i ∈ HAMPATH [1 mark]

(iv) hG4, v1, v4i ∈ HAMPATH [1 mark]

wwwwwwwwwwwww(continued at next page)

Page 7 of 9

CSC2047/Assignment 2 (v1)

wwwwwwwwwwwww(continued from previous page)

(b) DIMACS is a text-based format for Boolean formulas in CNF. Read the description at

http://people.sc.fsu.edu/~jburkardt/data/cnf/cnf.html. Encode the following

problems in DIMACS. Also state which ci,j is assigned which variable number. Afterwards,

use the webpage https://jgalenson.github.io/research.js/demos/minisat.html

to solve these SAT problems automatically. For each problem, provide the resulting output.

If the problem is satisfiable, provide the Hamilton path which corresponds to the solution.

(i) hG1, v1, v2i ∈ HAMPATH [1 mark]

(ii) hG2, v1, v3i ∈ HAMPATH [1 mark]

(iii) hG3, v1, v4i ∈ HAMPATH [1 mark]

(iv) hG4, v1, v4i ∈ HAMPATH [1 mark]

(c) SAT problems can be solved in O(2q

· p) where q is the number of variables and p the

length of the formula (total number of literals). Let EXPTIME =

S

k TIME(2nk) be

the set of languages which are decidable in exponential time.

(i) Provide the complexity of deciding HAMPATH via SAT using the O-notation depending

on the number of vertices n. [2 marks]

(ii) Is HAMPATH in EXPTIME? Justify your answer. [2 marks]

(iii) Is this method to solve HAMPATH faster than the one from the lecture? Justify your

answer. [2 marks]

(d) Describe an encoding of the following language to SAT:

ANYHAM = {hGi | G is a directed graph with a Hamiltonian path}

[2 marks]

(e) Describe an encoding of the following language to SAT:

HCIRC = {hGi | G = (V, E) is a directed graph and it has a Hamiltonian path

from some s ∈ V to some t ∈ V with (t, s) ∈ E} [2 marks]

(f) Describe how you could exclude a particular Hamiltonian path when constructing the SAT

problem (e.g. because you have already found it and you want to find another one).

[2 marks]

Page 8 of 9

CSC2047/Assignment 2 (v1)

7. Consider the recurrences below defined for n ≥ 0.

Note: The lecture discussing the methods necessary for solving this exercise is scheduled for

Thursday, February 27th, 2020.

f(n) = (1 if n = 0

f(n − 1) + 2n else

g(n) = (1 if n = 02g(n − 1) + 2n else

(a) Give the values for the following items.

(i) f(0) [1 mark]

(ii) g(1) [1 mark]

(iii) g(2) [1 mark]

(iv) f(10) [1 mark]

(b) Give a closed-form solution to the recurrence for f(n) and show your process for arriving

at this solution. [2 marks]

(c) Prove the correctness of your solution in (b) by induction. [2 marks]

(d) Prove that g(n) = 5 · 2

n − 2n − 4 by induction. [2 marks]

Page 9 of 9


版权所有:编程辅导网 2021 All Rights Reserved 联系方式:QQ:99515681 微信:codinghelp 电子信箱:99515681@qq.com
免责声明:本站部分内容从网络整理而来,只供参考!如有版权问题可联系本站删除。 站长地图

python代写
微信客服:codinghelp