From a570ce1671545830ccb60997e8e09c4390ce3148 Mon Sep 17 00:00:00 2001 From: Dev-XYS Date: Fri, 20 Jan 2017 18:17:06 +0800 Subject: [PATCH] =?UTF-8?q?=E5=B7=A6=E5=81=8F=E6=A0=91=E7=9A=84=E5=9F=BA?= =?UTF-8?q?=E6=9C=AC=E6=93=8D=E4=BD=9C?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Leftist-Tree.cpp | 81 ++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 81 insertions(+) create mode 100644 Leftist-Tree.cpp diff --git a/Leftist-Tree.cpp b/Leftist-Tree.cpp new file mode 100644 index 0000000..3a96757 --- /dev/null +++ b/Leftist-Tree.cpp @@ -0,0 +1,81 @@ +#include + +using namespace std; + +struct node +{ + node *lch, *rch; + int key, dis; + node(int _key = 0, int _dis = 0); +}*root, *nil; + +node::node(int _key, int _dis) : key(_key), dis(_dis) +{ + lch = rch = nil; +} + +void init() +{ + nil = new node(0, -1); + root = nil; +} + +inline void swap(node *&u, node *&v) +{ + node *temp = u; + u = v; + v = temp; +} + +void merge(node *&u, node *&v) +{ + if (u == nil) + { + u = v; + return; + } + if (v == nil) return; + if (u->key > v->key) swap(u, v); + merge(u->rch, v); + if (u->lch->dis < u->rch->dis) swap(u->lch, u->rch); + u->dis = u->rch->dis + 1; +} + +int extract_min() +{ + int res = root->key; + merge(root->lch, root->rch); + node *del = root; + root = root->lch; + delete del; + return res; +} + +int main() +{ + int op, x; + init(); + while (true) + { + scanf("%d", &op); + if (op == 1) + { + scanf("%d", &x); + node *o = new node(x, 0); + merge(root, o); + } + else if (op == 2) + { + printf("%d\n", extract_min()); + } + else if (op == 0) + { + break; + } + else + { + printf("No such command!\n"); + } + } + return 0; +}