và L R ( k ) tốt không chỉ vì chúng có thể được phân tích cú pháp hiệu quả mà còn bởi vì chúng ta có thể kiểm tra xem một ngữ pháp là L L ( k ) hay L R ( k )LL(k)LR(k)LL(k)LR(k)và bởi vì chúng ta có thể tạo các bảng cho chúng (các bảng phân tích được sử dụng để phân tích các chuỗi đầu vào). Lưu ý rằng đối với hai lớp này, việc có bảng phân tích cú pháp ngay lập tức cho phép bạn kiểm tra xem các ngữ pháp có trong các lớp hay không, bởi vì điều này là như vậy nếu và chỉ khi các bảng không có lỗi. Ngoài ra, có, có các lớp ngữ pháp mà chúng ta có thể phân tích cú pháp một cách hiệu quả nếu chúng ta có một bảng phân tích cú pháp, nhưng chúng ta không thể tạo bảng nếu nó tồn tại.
Bất kỳ sách giáo khoa về các phương pháp phân tích cú pháp sẽ dạy cho bạn cách tạo các bảng cho các phương thức và cũng có thể cho L R ( 1 ) (mặc dù S L R ( 1 ) phổ biến hơn). Các sách giáo khoa như Lý thuyết phân tích của Sippu và Soisalon-Soininen cũng xử lý việc tạo bảng phân tích cú pháp cho các ngữ pháp L L ( k ) và L R ( k ) .LL(1)LR(1)SLR(1)LL(k)LR(k)
Thật không may, đối với các ngữ pháp thực sự kỳ lạ, các bảng phân tích cho và L R ( k ) (mặc dù không phải cho L L ( 1 ) ) có thể nổ tung và trở nên khổng lồ; họ sẽ làm điều này ngay cả đối với các ngữ pháp thông thường nếu k đủ cao. Có sẵn các bài kiểm tra có thể kiểm tra xem một ngữ pháp là L L ( k ) hay L R ( k )LL(k)LR(k)LL(1)kLL(k)LR(k)hoặc không chạy trong thời gian đa thức (tạo bảng là theo cấp số nhân). Để biết chi tiết, đọc sách giáo khoa ở trên. Lưu ý rằng trong rất nhiều trường hợp, bảng có kích thước hợp lý, do đó không cần thử nghiệm.
Nếu bạn không muốn thử các giá trị của để xem chương trình của bạn có hoạt động không, nhưng thay vào đó, muốn máy tính của bạn tìm ra liệu có tồn tại giá trị k sao cho ngữ pháp của bạn là L L ( k ) hay L R ( k ) , bạn không may gặp may, vì điều này là không thể. Nếu ngữ pháp của bạn là L R ( k ) đối với một số k , bạn có thể quyết định liệu ngữ pháp của bạn có phải là L L ( c ) đối với một số c hay không , có thể khác với kkkLL(k)LR(k)LR(k)kLL(c)ck(xem tại đây để biết chi tiết).