--- 这里是 cjiaw 的小窝(●'◡'●) ---

正在玩命加载中......

CF_2055_C. The Trail

题目链接:Problem - C - Codeforces


题目大意:

从左上角到右下角的路径


思路:

直接设  行  列的矩阵每行之和或每列之和为 


#include<iostream>
#include<algorithm>
#include<cstring>
#include<cstdlib>
#include<cmath>
#include<vector>
#include<queue>
#include<deque>
#include<stack>
#include<set>
#include<map>
#include<unordered_set>
#include<unordered_map>
#include<bitset>
#include<tuple>
#define inf 72340172838076673
#define int long long
#define endl '\n'
#define F first
#define S second
#define  mst(a,x) memset(a,x,sizeof (a))
using namespace std;
typedef pair<int, int> pii;

const int N = 1008, mod = 998244353;

int n, m;
int e[N][N];
int s1[N], s2[N];

void solve() {

    mst(s1, 0), mst(s2, 0);
    string s;
    cin >> n >> m >> s;
    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= m; j++) {
            cin >> e[i][j];
            s1[i] += e[i][j];
            s2[j] += e[i][j];
        }
    }
    
    int x = 1, y = 1;
    for (int i = 0; i < s.size(); i++) {
        if (s[i] == 'R') {
            e[x][y] = -s2[y];
            s1[x] -= s2[y];
            y++;
        } else {
            e[x][y] = -s1[x];
            s2[y] -= s1[x];
            x++;
        }
    }
    
    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= m; j++) {
            if (i == n && j == m) e[i][j] = -s2[m];
            cout << e[i][j] << " ";
        }
        cout << endl;
    }
    
}

signed main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr), cout.tie(nullptr);
    
    int T = 1;
    cin >> T;
    while (T--) solve();
    
    return 0;
}

 

posted @ 2025-10-14 18:07  cjiaw  阅读(7)  评论(0)    收藏  举报