THEORY OF COMPUTATION

Introduction to Automata Theory, Languages, and Computation by John E Hopcroft, Rajeev Motwani and Jeffrey D. Ullman =>> download link