(Challenge) Delete DAG

All submissions for this problem are available.
###Read problems statements [Hindi](http://www.codechef.com/download/translated/DEC18/hindi/DLDAG.pdf) , [Vietnamese](http://www.codechef.com/download/translated/DEC18/vietnamese/DLDAG.pdf) , [Mandarin Chinese](http://www.codechef.com/download/translated/DEC18/mandarin/DLDAG.pdf) , [Russian](http://www.codechef.com/download/translated/DEC18/russian/DLDAG.pdf) and [Bengali](http://www.codechef.com/download/translated/DEC18/bengali/DLDAG.pdf) as well. You are given a directed acyclic graph with $N$ vertices (numbered $1$ through $N$) and $M$ edges. You want to destroy it all! To destroy the graph, you should delete all of its vertices. In one step, you are allowed to delete at most two vertices; you may only delete a vertex when there is no edge from it to another (not yet deleted) vertex. You may not delete two vertices when there is an edge between them either. Find a way to destroy the graph in the minimum number of steps. ### Input  The first line of the input contains two spaceseparated integers $N$ and $M$.  Each of the next $M$ lines contains two spaceseparated integers $U$ and $V$ denoting an edge from vertex $U$ to vertex $V$. ### Output  The first line of the output should contain a single integer $S$ denoting the minimum number of steps needed to destroy the graph.  Each of the next $S$ lines should describe one step; it should contain an integer $K$ ($1 \le K \le 2$), followed by a space and $K$ spaceseparated integers denoting the numbers of vertices deleted in this step. ### Constraints  $1 \le N, M \le 10^6$  the graph on the input does not contain any cycles or selfloops ### Scoring The score for each test file is $10 \cdot (C/S)^2$, where $C$ is the number of steps in which you deleted exactly $2$ vertices. The final score of your submission is equal to the sum of scores for each test file. There are twenty test cases. During the contest, the displayed score will account for exactly four test files, i.e. your score reflects your submission's performance on 20% (4/20) of the test files. However, if your program gets a nonAC verdict on any test file, your submission's verdict will be nonAC. In other words, an AC verdict denotes that your program runs successfully on all the test files. After the end of the contest, your score will be changed to include the sum of your program's scores over the other sixteen test files. ### Example Input ``` 6 6 1 2 2 3 1 3 3 4 3 5 1 6 ``` ### Example Output ``` 4 2 4 5 2 6 3 1 2 1 1 ```Author:  fekete 
Tags  fekete 
Date Added:  14112018 
Time Limit:  1 sec 
Source Limit:  50000 Bytes 
Languages:  C, CPP14, JAVA, PYTH, PYTH 3.6, PYPY, CS2, PAS fpc, PAS gpc, RUBY, PHP, GO, NODEJS, HASK, rust, SCALA, swift, D, PERL, FORT, WSPC, ADA, CAML, ICK, BF, ASM, CLPS, PRLG, ICON, SCM qobi, PIKE, ST, NICE, LUA, BASH, NEM, LISP sbcl, LISP clisp, SCM guile, JS, ERL, TCL, kotlin, PERL6, TEXT, SCM chicken, PYP3, CLOJ, COB, FS 
Comments
 Please login at the top to post a comment.
SUCCESSFUL SUBMISSIONS
Fetching successful submissions
HELP
If you are still having problems, see a sample solution here. 