Submission

Status:

[P-SSSSSSSSSSSSS]

Subtask/Task Score:

{0/100}

Score: 0

User: kavin8888

Problemset: อัศวินขี่ม้าขาว

Language: cpp

Time: 0.006 second

Submitted On: 2025-11-13 17:28:32


#include <bits/stdc++.h>
#define int long long
using namespace std;
#pragma GCC optimize("O3,unroll-loops,inline")
#pragma GCC target("avx2,bmi,bmi2,lzcnt,popcnt")
#define MAX_N 1000
vector<vector<int>> a(MAX_N+1,vector<int> (MAX_N+1));
vector<int> dp(MAX_N+1);
vector<int> rp(MAX_N+1);
int32_t main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
    int n, m;
    cin>>n>>m;
    for(int i=n;i>=1;i--) {
        for(int j=m;j>=1;j--) {	
            cin>>a[i][j];
        }
    }
    for(int i=1;i<=n;i++) {
        for(int j=1;j<=m;j++) {
            dp[j]=a[i][j];
            if(i!=1 || j!=1) {
                dp[j]+=max(rp[j],dp[j-1]);
            }
            dp[j]=min(0LL,dp[j]);
        }
        swap(rp,dp);
    }
    cout<<abs(rp[m])+1<<'\n';
    return 0;
}