시간 제한 | 메모리 제한 | 제출 | 정답 | 맞힌 사람 | 정답 비율 |
---|---|---|---|---|---|
1 초 | 128 MB | 11 | 7 | 7 | 100.000% |
The Cybersoft Computer Company (a leader in programming languages) has hired you to work on a new programming language named A--. Your task is to work on the array mapping tasks of the language. You will take an array reference such as x[5,6]
and map it to an actual physical address. In preparation for doing this, you will write a program that will read in several array declarations and references and give the physical address of each reference. The physical address output by the program should be an integer number in base 10.
The physical address of an array reference A[i1, i2,..., iD] is calculated from the formula C0 + C1i1 + C2i2 + ... + CDiD, where the constants C0...CD are calculated as specified below.
The first line of the input file contains two positive integers. The rst integer speci es N, the number of arrays de ned in the data le, and the second integer speci es R, the number of array references for which addresses should be calculated. The next N lines each de ne an array, one per line, and the following R lines contain one array reference per line for which an address should be calculated.
Each line which de nes an array contains, in the following order, the name of the array (which is limited to 10 characters), a positive integer which speci es the base address of the array, a positive integer which speci es the size in bytes of each array element, and D, the number of dimensions in the array (no array will have fewer than 1 or more than 10 dimensions). This is followed on the same line by D pairs of integers which represent the lower and upper bounds, respectively, of dimensions 1 . . . D of the array.
Each line which speci es an array reference contains the name of the array followed by the integer indexes i1, i2, . . . , iD where D is the dimension of the array.
The output file should contain the array references and the physical address. There should be one array reference and physical address per line. The formatting guidelines below must be adhered to.
For each line of output:
3 4 ONE 1500 2 2 0 3 1 5 TWO 2000 4 3 1 4 0 5 5 10 THREE 3000 1 1 1 9 ONE 2 4 THREE 7 TWO 2 0 6 TWO 3 3 9
ONE[2, 4] = 1526 THREE[7] = 3006 TWO[2, 0, 6] = 2148 TWO[3, 3, 9] = 2376