-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path10b.m
More file actions
executable file
·54 lines (54 loc) · 1.05 KB
/
10b.m
File metadata and controls
executable file
·54 lines (54 loc) · 1.05 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#!/usr/bin/octave -qf
data=textread("10.txt", "%s");
lines=0;
for i=1:length(data)
stack=0;
k=0;
incomplete=1;
for j=1:length(data{i})
switch (data{i}(j))
case "("
k+=1; stack(k)=1;
case "["
k+=1; stack(k)=2;
case "{"
k+=1; stack(k)=3;
case "<"
k+=1; stack(k)=4;
case ")"
if (stack(k)==1)
k-=1;
else
incomplete=0; break;
endif
case "]"
if (stack(k)==2)
k-=1;
else
incomplete=0; break;
endif
case "}"
if (stack(k)==3)
k-=1;
else
incomplete=0; break;
endif
case ">"
if (stack(k)==4)
k-=1;
else
incomplete=0; break;
endif
otherwise
printf('This should not happen!\n');
endswitch
endfor
if (incomplete)
lines+=1;
linescore(lines)=0;
for i=k:-1:1
linescore(lines)=5*linescore(lines)+stack(i);
endfor
endif
endfor
printf('The middle score is %d\n', median(linescore));