Submission
Status:
PPPPPPPPPP
Subtask/Task Score:
100/100
Score: 100
User: Poon
Problemset: ปริมาตรน้ำท่วม
Language: cpp
Time: 0.002 second
Submitted On: 2025-10-09 09:42:31
#include <iostream>
using namespace std;
int main()
{
int n;
cin>>n;
int d[n];
int max=-1;
int c=0;
for(int k=0;k<n;k++)
{
cin>>d[k];
if(max<d[k])
{
max=d[k];
}
}
int grid[max+1][n];
for(int i=0;i<max+1;i++)
{
for(int j=0;j<n;j++)
{
grid[i][j]=0;
}
}
for(int i=0;i<n;i++)
{
for(int j=max;j>=max-d[i];j--)
{
grid[j][i]=2;
}
}
for(int i=0;i<max+1;i++)
{
for(int j=0;j<n;j++)
{
if(grid[i][j]==0)
{
bool left=0,right=0;
for(int k=j;k<n;k++)
{
if(grid[i][k]==2)
{
right=1;
}
}
for(int k=j;k>=0;k--)
{
if(grid[i][k]==2)
{
left=1;
}
}
if(left==1&&right==1)
{
grid[i][j]=1;
}
}
}
}
for(int i=0;i<max+1;i++)
{
for(int j=0;j<n;j++)
{
if(grid[i][j]==1)
{
c++;
}
}
}
cout<<c;
}