Survivors (video game)

Survivors (also known as The Survivors)[1][2] is a game published by Atlantis Software in 1986 for the ZX Spectrum. It was ported to the MSX, Atari 8-bit family, Commodore 64, Commodore 16, Acorn Electron, and BBC Micro (all in 1987) and the Amstrad CPC (1988). It is a puzzle game based on the "rocks and diamonds" mechanics of Boulder Dash.

Survivors
Developer(s)Glynn Carey
Publisher(s)Atlantis
Platform(s)ZX Spectrum, Acorn Electron, Atari 8-bit, BBC Micro, Commodore 64, Commodore 16, MSX
Release1986: Spectrum
1987: Atari, BBC, C64, C16, Electron, MSX
1988: Amstrad
Genre(s)Puzzle
Mode(s)Single-player

Gameplay

Start of the first game level (Electron)

The game is set in 2087 in a 'hibernation dome' which has been damaged in a nuclear war. It holds 1000 survivors (who are in stasis) but cannot be accessed by humans because of fallen earth and boulders. The player must control three droids to gain access to, and teleport out, the survivors. The dome is also populated by guardian droids that had been left to maintain life support functions but have been damaged by the nuclear fallout and become hostile. The survivors must all be evacuated before the time limit runs out and the radiation becomes too strong.

The game uses the 'rocks and diamonds' mechanics as popularised in the game Boulder Dash whereby the player can dig through earth and push boulders but where boulders will fall from above if area below them is cleared. With the emphasis more on the puzzle element, Survivors is closer to Repton. The main twist with this game is that each droid can only perform one of the functions usually carried out by the player in similar games. The player must switch between droids depending on what they need to do. Droid 1 can tunnel through earth, Droid 2 can teleport survivors home (this game's equivalent of collecting diamonds) and Droid 3 can push boulders. This means that if any droid is trapped or destroyed then the game cannot be completed.

The droids lose energy if a boulder falls on top of them or if they touch one of the faulty guardian droids. The guardian droids can be destroyed by dropping boulders on them or trapped behind boulders.

Reception

The game was first released for the ZX Spectrum, where it received mixed reviews. Complaints included 'jerky movement'[3][4] and dull graphics and sound[3][4] but praise was given for playability and value for money.[4][5] Crash awarded an overall score of 70%,[4] Your Sinclair gave it 6/10[5] and C&VG only gave marks between 4/10 and 5/10 (without awarding an overall score).[3]

The game was then ported to a number of other formats where it received generally more positive reviews. Zzap!64 gave the C64 version a score of 79%, concluding that the game was "taxing both mentally and dexterously and Boulderdash fans suffering from withdrawal symptoms should enjoy Survivors quite a lot".[6] The Micro User was even more complimentary, commenting that it "could well knock Repton off its perch", and Electron User awarded it the 'Golden Game' title with an overall score of 9/10 (including 10/10 for both playability and value for money).[7]

gollark: Oh, right, array indexing.
gollark: ```python# parsita-based pseudocode syntax parserfrom stmt import *from parsita import *from parsita.util import constantdef compose(f, g): return lambda x: f(g(x))def map_expr(x): start, end = x if end == "": return start return Op([start, end[1]], end[0])def map_unop_expr(x): return Op(x[1], x[0])def aliases(name, aliases): p = lit(name) for alias in aliases: p |= (lit(alias) > (lambda _: name)) return pclass ExprParser(TextParsers): ε = lit("") IntLit = reg("\-?[0-9]+") > compose(IntLit, int) StrLit = "'" >> reg("[^']*") << "'" > StrLit # TODO escapes (not in "spec" but could be needed) FloatLit = reg("\-?[0-9]+\.[0-9]+") > compose(FloatLit, float) Identifier = reg("[a-zA-Z_]+[a-zA-Z_0-9]*") > Var BracketedExpr = "(" >> Expr << ")" UnaryOperator = lit("NOT") Start = FloatLit | StrLit | IntLit | BracketedExpr | (UnaryOperator & Expr > map_unop_expr) | Identifier # avoid left recursion problems by not doing left recursion # AQA pseudocode does not appear to have a notion of "operator precedence", simplifying parsing logic nicely BinaryOperator = aliases("≤", ["<="]) | aliases("≠", ["!="]) | aliases("≥", [">="]) | lit("DIV") | lit("MOD") | lit("AND") | lit("OR") | reg("[+/*\-=<>]") End = (BinaryOperator & Expr) | ε Expr = (Start & End) > map_exprparse = ExprParser.Expr.parsex = parse("1+2+3 != 6 AND NOT 4 AND x + y")if isinstance(x, Failure): print(x.message)else: print(x.value)```
gollark: <@332271551481118732> Expression parsing is done, I think.
gollark: I wonder if AQA pseudocode *does* have operator precedence. We may need to harvest exam papers.
gollark: This will allow 3% more efficient harnessing of character set anomalies.

References

This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.