Logo 2
时间: 1ms 内存:128M
描述:
Logo is a programming language built around a turtle. Commands in the language cause the turtle to move. The turtle has a pen attached to it. As the turtle moves, it draw lines on the page. The turtle can be programmed to draw interesting pictures.
We are interested in making the turtle draw a picture, then return to the point that it started from. For example, we could give the turtle the following program:
fd 100 lt 120 fd 100 lt 120 fd 100
The command fd causes the turtle to move forward by the specified number of units. The command lt causes the turtle to turn left by the specified number of degrees. Thus the above commands cause the turtle to draw an equilateral triangle with sides 100 units long. Notice that after executing the commands, the turtle ends up in the same place as it started. The turtle understands two additional commands. The command bk causes the turtle to move backward by the specified number of units. The command rt causes the turtle to turn right by the specified number of degrees. The distances and angles in all commands are always non-negative integers.
Unfortunately, we have been messy in writing the program down, and cannot read our own writing. One of the numbers in the program is missing. Assuming the turtle ends up at the place that it started at the end of its journey, can you find the missing number?
输入:
The first line of input contains one integer specifying the number of test cases to follow. Each test case starts with a line containing one integer, the number of commands to follow. The commands follow, one on each line. Each test case will contain no more than 1000 commands. The argument of each command is either an integer or a question mark (?). There will be exactly one question mark in each test case.
输出:
For each test case, output line containing a single integer
n
such that when the question mark in the program is replaced by
n
, the turtle ends up at the same point that it started from once the program completes. If the question mark is the argument of an
lt
or
rt
command, the angle in the output must be between 0 and 359 degrees, inclusive. The correct answer will always be an integer, and we guarantee that for every test case, there will be only one correct answer.
示例输入:
1
5
fd 100
lt 120
fd ?
lt 120
fd 100
示例输出:
100
提示:
参考答案(内存最优[1008]):
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#define EPS 0.0000001
char buf[100000];
char cmd[1100];
char dist[1100][100];
double X, Y;
double HD;
void FD(int d) {
    X += d*cos(HD/180*M_PI);
    Y += d*sin(HD/180*M_PI);
    //printf("FD %d to %lf %lf\n", d, X, Y);
}
void LT(int d) {
    HD+=d;
}
void HOME() {
    HD = 0;
    X = 0;
    Y = 0;
}
int myatoi(char* st, int other) {
    if(st[0] == '?') return other;
    return atoi(st);
}
int main() {
    int CASES;
    scanf("%d ", &CASES);
    while(CASES--) {
       // int cnt;
        int i;
        int turn = 0;
        int n;
        scanf("%d", &n);
       
        for(i=0;i<n;i++) {
			
            scanf("%s%s", buf,dist[i]);
            cmd[i] = buf[0];
        }
        for(i=0; i<n; i++) {
            if(dist[i][0] != '?') continue;
            if(cmd[i] == 'l') turn = 1;
            if(cmd[i] == 'r') turn = 1;
        }
        if(turn) {
            int ang;
            for(ang = 0; ang < 360; ang++) {
                    //printf("angle: %d\n", ang);
                HOME();
                for(i=0; i<n; i++){
                    switch(cmd[i]) {
                        case 'f': FD(atoi(dist[i])); break;
                        case 'b': FD(-atoi(dist[i])); break;
                        case 'l': LT(myatoi(dist[i],ang)); break;
                        case 'r': LT(-myatoi(dist[i],ang)); break;
                    }
                }
                if(fabs(X)+fabs(Y) < EPS) {
                    printf("%d\n", ang);
                    goto next;
                }
            }
                puts("no angle worked");
        } else {
            HOME();
            for(i=0; i<n; i++){
                switch(cmd[i]) {
                    case 'f': FD(myatoi(dist[i],0)); break;
                    case 'b': FD(-myatoi(dist[i],0)); break;
                    case 'l': LT(atoi(dist[i])); break;
                    case 'r': LT(-atoi(dist[i])); break;
                }
            }
            printf("%.0lf\n", sqrt(X*X+Y*Y));
        }
next:;
    }
    return 0;
}参考答案(时间最优[4]):
#include <math.h>
#include <stdio.h>
#include <stdlib.h>
#define EPS 0.0000001
char buf[100000];
char cmd[1100];
char dist[1100][100];
double X, Y;
double HD;
void FD(int d) {
    X += d*cos(HD/180*M_PI);
    Y += d*sin(HD/180*M_PI);
    //printf("FD %d to %lf %lf\n", d, X, Y);
}
void LT(int d) {
    HD+=d;
}
void HOME() {
    HD = 0;
    X = 0;
    Y = 0;
}
int myatoi(char* st, int other) {
    if(st[0] == '?') return other;
    return atoi(st);
}
int main() {
    int CASES;
    scanf("%d ", &CASES);
    while(CASES--) {
       // int cnt;
        int i;
        int turn = 0;
        int n;
        scanf("%d", &n);
       
        for(i=0;i<n;i++) {
			
            scanf("%s%s", buf,dist[i]);
            cmd[i] = buf[0];
        }
        for(i=0; i<n; i++) {
            if(dist[i][0] != '?') continue;
            if(cmd[i] == 'l') turn = 1;
            if(cmd[i] == 'r') turn = 1;
        }
        if(turn) {
            int ang;
            for(ang = 0; ang < 360; ang++) {
                    //printf("angle: %d\n", ang);
                HOME();
                for(i=0; i<n; i++){
                    switch(cmd[i]) {
                        case 'f': FD(atoi(dist[i])); break;
                        case 'b': FD(-atoi(dist[i])); break;
                        case 'l': LT(myatoi(dist[i],ang)); break;
                        case 'r': LT(-myatoi(dist[i],ang)); break;
                    }
                }
                if(fabs(X)+fabs(Y) < EPS) {
                    printf("%d\n", ang);
                    goto next;
                }
            }
                puts("no angle worked");
        } else {
            HOME();
            for(i=0; i<n; i++){
                switch(cmd[i]) {
                    case 'f': FD(myatoi(dist[i],0)); break;
                    case 'b': FD(-myatoi(dist[i],0)); break;
                    case 'l': LT(atoi(dist[i])); break;
                    case 'r': LT(-atoi(dist[i])); break;
                }
            }
            printf("%.0lf\n", sqrt(X*X+Y*Y));
        }
next:;
    }
    return 0;
}题目和答案均来自于互联网,仅供参考,如有问题请联系管理员修改或删除。
