0 QTRS
↳1 Overlay + Local Confluence (⇔)
↳2 QTRS
↳3 DependencyPairsProof (⇔)
↳4 QDP
↳5 DependencyGraphProof (⇔)
↳6 AND
↳7 QDP
↳8 QDP
↳9 QDPOrderProof (⇔)
↳10 QDP
↳11 PisEmptyProof (⇔)
↳12 TRUE
↳13 QDP
↳14 QDPOrderProof (⇔)
↳15 QDP
↳16 PisEmptyProof (⇔)
↳17 TRUE
↳18 QDP
app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
APP(cons(X, XS), YS) → APP(XS, YS)
FROM(X) → FROM(s(X))
ZWADR(cons(X, XS), cons(Y, YS)) → APP(Y, cons(X, nil))
ZWADR(cons(X, XS), cons(Y, YS)) → ZWADR(XS, YS)
PREFIX(L) → ZWADR(L, prefix(L))
PREFIX(L) → PREFIX(L)
app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
FROM(X) → FROM(s(X))
app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
APP(cons(X, XS), YS) → APP(XS, YS)
app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
APP(cons(X, XS), YS) → APP(XS, YS)
[APP2, cons2]
app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
ZWADR(cons(X, XS), cons(Y, YS)) → ZWADR(XS, YS)
app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
The following pairs can be oriented strictly and are deleted.
The remaining pairs can at least be oriented weakly.
ZWADR(cons(X, XS), cons(Y, YS)) → ZWADR(XS, YS)
trivial
app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)
PREFIX(L) → PREFIX(L)
app(nil, YS) → YS
app(cons(X, XS), YS) → cons(X, app(XS, YS))
from(X) → cons(X, from(s(X)))
zWadr(nil, YS) → nil
zWadr(XS, nil) → nil
zWadr(cons(X, XS), cons(Y, YS)) → cons(app(Y, cons(X, nil)), zWadr(XS, YS))
prefix(L) → cons(nil, zWadr(L, prefix(L)))
app(nil, x0)
app(cons(x0, x1), x2)
from(x0)
zWadr(nil, x0)
zWadr(x0, nil)
zWadr(cons(x0, x1), cons(x2, x3))
prefix(x0)