You are a programmer. Let's propagandize programming languages and increase the number of believers of the programming languages. Overreach rivals and become the pontiff of programming languages!
If you want to read the game rule in a programming language, please see pseudo code.
Get more victory points, which are calculated with the number of believers of each programming language, than other players.
There are four players and six programming languages.
Lang Wars is a turn-based game. Players propagandize their favorite programming languages and gather believers. Because players' actions are partially hidden, it is important to bargain with each other.
Games end in 9 turns, then players gain victory points corresponding to the number of believers of programming languages. The player who gathered the most number of the believers of a programming language gets the victory points of the language, in contrast, the player who gathered the least number of the believers of a programming language loses the victory points of the language. Thus, players should propagate their favorite programming languages and gather more believers than the other players, and also, propagate the other programming languages to prevent losing victory points. The player who gains the most victory points will win!
The game system sets random attention degree (from 3 to 6) to every programming language, and reveals them to players at the beginning. A language with higher attention degree has more victory points. Players who gathered the most/least number of believers of this language will gain/lose victory points.
There are two types of turns, workday turns and holiday turns. The first turn is workday. Workday and holiday turns will alternately appear. In other words, two turns make one week. Odd turns are workday and even turns are holiday. Players simultaneously select programming languages to propagate. They select languages to propagate five times in a workday turn, and twice in a holiday turn. You get one believer for one propagation in weekday, and two believers in holiday. Players can freely choose which programming languages to propagate. For example, players can choose five programming languages to propagate each one time, or propagate the same programming language five times in a workday turn. In addition, players who propagate the same programming language with others, will not influence others to gather believers.
The number of the believers of each programming language will be calculated after all players select propagating languages. If the turn is workday, which player propagates which programming language is revealed. If the turn is holiday, only how many times each programming language is propagated is revealed.
The following table indicates the propagation feature in a workday turn and a holiday turn.
Workday | Holiday | |
---|---|---|
Propagation times | 5 | 2 |
Number of believers gathered per propagation | 1 | 2 |
Revelation of propagation information | ALL | For each programming language, the number of propagation times |
If it is the fifth turn of the game, everyone will be notified how many believers each player gathered for each programming language so far, even in holidays.
After 9 turns, the game ends and victory points are calculated.
The player who gathered the most/least number of the believers of a programming language gains/loses the attention degree of the language as victory points. When multiple players gathered the most/least number of the believers, they gain/lose the attention degree divided by the number of the players. Floating-point divisions are used in calculating victory points.
After victory points of all the programming languages are calculated, the player who gained the most victory points wins. When there are multiple players gained the most victory points, the game ends in a draw.
AI programs are executed at the start of the game.
AI programs should print READY
and the newline character ("\n") to the standard output, and then read the settings of game.
Be sure to flush the standard output after printing.
Then, AI programs read current propagation information of each turn, and print the selected languages.
The thinking time of AI is limited. If an AI program exceeds the limited thinking time, it will be terminated by force and its behavior will be regarded as "select language 0 always" until the end.
When the AI programs prepared for the game, they must print READY
and the newline character ("\n") to the standard output.
Be sure to flush the standard output after printing.
Note that, the ready message must be printed within 5 seconds from game start, otherwise the AI program will be terminated by force.
When the game starts (before the 1st turn), the game system sends settings to every AI program through the standard input. The format of settings is listed as following:
T P N A0 A1 A2 ... A5
- T: The number of all turns (always 9).
- P: The number of players (always 4).
- N: The number of programming language (always 6).
- Ai: The attention degree of language i.
At the beginning of each turn, current information is sent through the standard input with the following format:
T D B00 B01 B02 B03 B10 B11 B12 B13 B20 B21 B22 B23 : : B50 B51 B52 B53 R0 R1 R2 ... R5 P0 P1 P2 ... P5
- T: Current turn. (starts from 1)
- D: "W" stand for workday turn, "H" stand for holiday turn.
- Bij: The visible number (only counting the believers gathered in workday turn) of believers of programming language i gathered by player j. The player 0 is your AI program. In the sixth turn and later turns, the number includes believers gathered in holidays before fifth turn.
- Ri: Your real number of believers of programming language i (counting the believers gathered in both workday and holiday turns).
- Pi: The number of times the programming language i was propagated in the previous holiday turn.
The last line (P0 P1 P2 ... P5) is only revealed in workday turns.
Print the language to propagate to the standard output with the following format:
-
Workday Turn
L0 L1 L2 L3 L4
-
Holiday Turn
L0 L1
Li: The number of programming language to propagate (from 0 to 5). The order of L0 to L4 is not concerned.
Please terminate the output with the newline character ("\n"), and be sure to flush the standard output after printing. Once an AI program prints its action, its turn finishes. Note that, if an AI program does not print its action within 1 second from the beginning of a turn, it will be terminated by force.
programming_language = (attention, revealed_believers[4], real_believers[4])
main:
init
while turn <= 9:
process_turn
turn += 1
finish
init:
players = player[4]
languages = programming_language[6] (rand(3, 6), [0, 0, 0, 0], [0, 0, 0, 0])
turn = 1
process_turn:
for l in languages:
display_to_all_players(l.attention)
display_to_all_players(l.revealed_believers)
if not is_holiday:
display_to_all_players(l.propagated)
l.propagated = 0
for p in players:
for i in [1 .. (is_holiday ? 2 : 5)]:
target = languages[p.selected[i]]
target.revealed_believers[p] += (is_holiday ? 0 : 1)
target.real_believers[p] += (is_holiday ? 2 : 1)
target.propagated += 1
if turn == 5:
for h in heroines:
h.revealed_believers = h.real_believers
is_holiday:
turn % 2 == 0
finish:
for l in languages:
best_players = players.max_by(p -> l.real_believers[p])
for p in best_players:
p.victory_points += h.attention / best_players.size
worst_players = players.min_by(p -> l.real_believers[p])
for p in worst_players:
p.victory_points -= h.attention / worst_players.size
winners = players.max_by(p -> p.victory_points)
draw if winners.size > 1