303894: CF750D. New Year and Fireworks

Memory Limit:256 MB Time Limit:2 S
Judge Style:Text Compare Creator:
Submit:0 Solved:0

Description

New Year and Fireworks

题意翻译

烟花绽放时分为n层,每层会前进ti格,当进入下一层是向左右45°分开前进。 问在网格中,有多少网格至少被烟花经过一次?

题目描述

One tradition of welcoming the New Year is launching fireworks into the sky. Usually a launched firework flies vertically upward for some period of time, then explodes, splitting into several parts flying in different directions. Sometimes those parts also explode after some period of time, splitting into even more parts, and so on. Limak, who lives in an infinite grid, has a single firework. The behaviour of the firework is described with a recursion depth $ n $ and a duration for each level of recursion $ t_{1},t_{2},...,t_{n} $ . Once Limak launches the firework in some cell, the firework starts moving upward. After covering $ t_{1} $ cells (including the starting cell), it explodes and splits into two parts, each moving in the direction changed by $ 45 $ degrees (see the pictures below for clarification). So, one part moves in the top-left direction, while the other one moves in the top-right direction. Each part explodes again after covering $ t_{2} $ cells, splitting into two parts moving in directions again changed by $ 45 $ degrees. The process continues till the $ n $ -th level of recursion, when all $ 2^{n-1} $ existing parts explode and disappear without creating new parts. After a few levels of recursion, it's possible that some parts will be at the same place and at the same time — it is allowed and such parts do not crash. Before launching the firework, Limak must make sure that nobody stands in cells which will be visited at least once by the firework. Can you count the number of those cells?

输入输出格式

输入格式


The first line of the input contains a single integer $ n $ ( $ 1<=n<=30 $ ) — the total depth of the recursion. The second line contains $ n $ integers $ t_{1},t_{2},...,t_{n} $ ( $ 1<=t_{i}<=5 $ ). On the $ i $ -th level each of $ 2^{i-1} $ parts will cover $ t_{i} $ cells before exploding.

输出格式


Print one integer, denoting the number of cells which will be visited at least once by any part of the firework.

输入输出样例

输入样例 #1

4
4 2 2 3

输出样例 #1

39

输入样例 #2

6
1 1 1 1 1 3

输出样例 #2

85

输入样例 #3

1
3

输出样例 #3

3

说明

For the first sample, the drawings below show the situation after each level of recursion. Limak launched the firework from the bottom-most red cell. It covered $ t_{1}=4 $ cells (marked red), exploded and divided into two parts (their further movement is marked green). All explosions are marked with an 'X' character. On the last drawing, there are $ 4 $ red, $ 4 $ green, $ 8 $ orange and $ 23 $ pink cells. So, the total number of visited cells is $ 4+4+8+23=39 $ . ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF750D/958e71e20888e0f3c92e01fa2be2e012117f122b.png)For the second sample, the drawings below show the situation after levels $ 4 $ , $ 5 $ and $ 6 $ . The middle drawing shows directions of all parts that will move in the next level. ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF750D/c21fe29a69f3371f920085202e17e34b6a0270b1.png)

Input

题意翻译

烟花绽放时分为n层,每层会前进ti格,当进入下一层是向左右45°分开前进。 问在网格中,有多少网格至少被烟花经过一次?

加入题单

算法标签: