Ybadoo - Soluções em Software Livre
Tutoriais
Compiladores

Desenvolva um programa na linguagem de programação SIMPLE, que apresente o produto dos números fornecidos pelo usuário, até que o usuário forneça o número zero. Por exemplo, caso os valores fornecidos pelo usuário sejam 1, 7, 4, 3 e 0, o programa deverá apresentar como resposta o valor 84, ou seja, 1 * 7 * 4 * 3. Posteriormente, apresente a identificação de todos os tokens utilizados na elaboração do programa.

 

10 input s
15 if s == 0 goto 40
20 input n
25 if n == 0 goto 40
30 let s = s * n
35 goto 20
40 print s
45 end
Tabela de símbolos
CódigoValor CódigoValor CódigoValor
0010 01s 0215
030 0440 0520
06n 0725 0830
0935 1045   
[51, 00, (01, 01)] // 10
[62, , (01, 04)] // input
[41, 01, (01, 10)] // s
[10, , (01, 11)] // ENTER
[51, 02, (02, 01)] // 15
[66, , (02, 04)] // if
[41, 01, (02, 07)] // s
[31, , (02, 09)] // ==
[51, 03, (02, 12)] // 0
[65, , (02, 14)] // goto
[51, 04, (02, 19)] // 40
[10, , (02, 21)] // ENTER
[51, 05, (03, 01)] // 20
[62, , (03, 04)] // input
[41, 06, (03, 10)] // n
[10, , (03, 11)] // ENTER
[51, 07, (04, 01)] // 25
[66, , (04, 04)] // if
[41, 06, (04, 07)] // n
[31, , (04, 09)] // ==
[51, 03, (04, 12)] // 0
[65, , (04, 14)] // goto
[51, 04, (04, 19)] // 40
[10, , (04, 21)] // ENTER
[51, 08, (05, 01)] // 30
[63, , (05, 04)] // let
[41, 01, (05, 08)] // s
[11, , (05, 10)] // =
[41, 01, (05, 12)] // s
[23, , (05, 14)] // *
[41, 06, (05, 16)] // n
[10, , (05, 17)] // ENTER
[51, 09, (06, 01)] // 35
[65, , (06, 04)] // goto
[51, 05, (06, 09)] // 20
[10, , (06, 11)] // ENTER
[51, 04, (07, 01)] // 40
[64, , (07, 04)] // print
[41, 01, (07, 10)] // s
[10, , (07, 11)] // ENTER
[51, 10, (08, 01)] // 45
[67, , (08, 04)] // end
[03, , (08, 07)] // ETF