Problem J: Train Tracks
Andy loves his set of wooden trains and railroad tracks. Each day, Daddy has to build a new track for him. The tracks he likes best form a simple loop with no branches or dead ends, so he can run his trains around and around for hours until it is time for the big crash that destroys the whole construction.
So here is the question: Given a set of track pieces, can you form a simple loop with them, while using up all the pieces?
Each piece of track is described by the connectors at both ends. A standard piece has one "male" and one "female" connector. But there are also track pieces with two male or two female connectors, as shown in the front right of the picture.
To fit together, each male connector must be connected to a female connector. Unlike real wooden tracks, our pieces are assumed to be flexible, so their length or shape is not an issue here. However, you may not connect the two ends of the same piece together.
Input begins with the number of test cases. Each following line contains one test case. Each test case consists of a list of between 1 and 50 (inclusive) train track pieces. A piece is described by two code letters: M for male or F for female connector. Pieces are separated by space characters.
For each test case, output a line containing either LOOP
or NO LOOP
to indicate whether or not all the pieces can be joined into a single loop.
Sample input
4 MF MF FM FF MF MM MM FF MF MF MF MF FF
Sample output
LOOP LOOP LOOP NO LOOP
#include<stdio.h> #include<string.h> char a[200]; int main() { int n,i; scanf("%d",&n); getchar(); while(n--) { int m=0,f=0; gets(a); for(i=0;i<strlen(a);i++) { if(a[i]=='M') m++; if(a[i]=='F') f++; } if(m==f&&m!=1) puts("LOOP"); else puts("NO LOOP"); } return 0; }