PAT甲级2020秋季

PAT甲级2020秋季

//01  
#include <iostream>
#include <set>
#include <algorithm>
#include <vector>
#include <unordered_map>
#include <cmath>
#include <cstring>
using namespace std;

int n, m, k;
int lw[10009];
int milkl[10009];
int milkr[10009];
int minn = 200;

int main() {
    cin >> n;
    for(int i = 0 ; i < n; i++)
        scanf("%d", &lw[i]);
    int pre = minn;
    milkl[0] = milkr[n-1] = minn;
    for(int i = 1 ; i < n; i++){
        if(lw[i] > lw[i-1]){
            milkl[i] = pre+100;
        }else if(lw[i] == lw[i-1]){
            milkl[i] = pre;
        }else{
            milkl[i] = minn;
        }
        pre = milkl[i];
    }
    for(int i = n-2 ; i >= 0; i--){
        if(lw[i] > lw[i+1]){
            milkr[i] = pre+100;
        }else if(lw[i] == lw[i+1]){
            milkr[i] = pre;
        }else{
            milkr[i] = minn;
        }
        pre = milkr[i];
    }
    int sum = 0;
    for(int i = 0 ; i < n; i++){
        sum += max(milkl[i], milkr[i]);
    }
    printf("%d", sum);
}

// 02 21->25
#include <iostream>
#include <set>
#include <algorithm>
#include <vector>
#include <unordered_map>
#include <cmath>
#include <cstring>
using namespace std;

int n, m, k, cnt = 0;
int landcost[10009];

int main() {
    scanf("%d %d", &n, &m);
    for(int i = 0 ; i < n; i++)
        scanf("%d", &landcost[i]);

    for(int i = 0; i < n; i++){
        int sum = 0;
        for(int j = 0; j < n && i+j < n; j++){
            sum += landcost[i+j];
            if(sum <= m) cnt++;
            else break;
        }
    }
    printf("%d\n", cnt);
    return 0;
}

// 03 21
#include <iostream>
#include <set>
#include <algorithm>
#include <vector>
#include <unordered_map>
#include <cmath>
#include <map>
#include <cstring>
using namespace std;

int n, m, k, cnt = 0;
int in[30], pre[30], pos[30];
vector<vector<int>> ans;

void level(int h1, int h2, int l, int lev){
    if(l == 0) return; 
    int idx = pos[pre[h1]];
    ans[lev].emplace_back(in[idx]);
    int l1 = idx - h2;
    int l2 = l - l1 - 1;
    if(l1 != 0)
        level(h1+1, h2, l1, lev+1);
    if(l2 != 0)
        level(h1+l1+1, idx+1, l2, lev+1);
}

int main() {
    cin >> n;
    for(int i = 0 ; i < n; i++){
        scanf("%d", &in[i]);
        pos[in[i]] = i;
    }
    for(int i = 0 ; i < n; i++)
        scanf("%d", &pre[i]);
    ans.resize(n+1);

    level(0, 0, n, 0);
    int l = 0;
    while(!ans[l].empty()){
        if(l != 0) printf(" ");
        cout << ans[l][0];
        l++;
    }
    return 0;
}

// 04 SPFA算法!!!
#include <bits/stdc++.h>
using namespace std;

const int maxv = 1010;
const int INF = 0x7fffffff;

int n, m, k;
int in[maxv] = {0}, indegree[maxv] = {0};
int w[maxv], dis[maxv], seq[maxv], pre[maxv];
int G[maxv][maxv], money[maxv][maxv];
vector<int> post[maxv];   //记录后继结点

void SPFA(){
    queue<int> q;
    fill(pre, pre+maxv, -1);
    fill(dis, dis+maxv, INF);
    fill(w, w+maxv, 0);
    for(int i = 0; i < n; i++){
        if(!indegree[i]){//源点初始化并入队
            dis[i] = 0;
            w[i] = 0;
            q.push(i);
        }
    }
    while(!q.empty()){
        int u = q.front();
        q.pop();
        for(int j = 0; j < post[u].size(); j++){
            int v = post[u][j];
            indegree[v]--;
            //若弧尾入度松弛操作后为0 加入队列作为新的源点
            if(!indegree[v])   q.push(v);

            //主导权值
            if(dis[u] + G[u][v] < dis[v]){
                dis[v] = dis[u] + G[u][v];
                w[v] = w[u] + money[u][v];    //此处对权值的更新不要忘
                pre[v] = u;
            }else if(dis[u] + G[u][v] == dis[v]){
                //副权值判断
                if(w[u] + money[u][v] > w[v]){
                    w[v] = w[u] + money[u][v];    //注意不要忘了这句话,即更新最大权值(幸福值)
                    pre[v] = u;
                }
            }
        }
    }
}

int main(){
    int T1, T2, S, D;
    bool flag = true;
    scanf("%d %d", &n, &m);
    fill(G[0], G[0]+maxv*maxv, INF);
    for(int i = 0; i < m; i++){
        scanf("%d %d %d %d", &T1, &T2, &S, &D);
        indegree[T2]++;
        in[T2]++;
        G[T1][T2] = S;
        money[T1][T2] = D;
        post[T1].push_back(T2);
    }
    scanf("%d", &k);
    for(int i = 0; i < k; i++)  scanf("%d", &seq[i]);
    SPFA();
    //最短路径遍历寻一遍后还剩入度不为0的即为成环的点排除
    for(int i = 0; i < k; i++){
        if(indegree[seq[i]]){
            flag = false;
            break;
        }
    }
    if(flag){
        printf("Okay.\n");
        for(int i = 0; i < k; i++){
            vector<int> ans;
            for(int pos = seq[i]; pos != -1; pos = pre[pos]){
                ans.push_back(pos);
            }
            reverse(ans.begin(), ans.end());
            //原始源点直接输出
            if(!in[seq[i]]) printf("You may take test %d directly.\n", seq[i]);
            else    for(int j = 0; j < ans.size(); j++)     printf("%d%s", ans[j], j == ans.size()-1 ? "\n":"->");
        }
    }else{
        printf("Impossible.\n");
        for(int i = 0; i < k; i++){
            if(!in[seq[i]]) printf("You may take test %d directly.\n", seq[i]);
            else    printf("Error.\n");
        }
    }
    return 0;
}#

上一篇:PAT 1006 换个格式输出整数


下一篇:PAT甲级2020冬季