其他分享
首页 > 其他分享> > AtCoder Beginner Contest 224

AtCoder Beginner Contest 224

作者:互联网

AtCoder Beginner Contest 224

A - Tires

思路分析:

代码如下:

#include <bits/stdc++.h>
using namespace std;
int main()
{
        ios::sync_with_stdio(0);
        cin.tie(0);
        cout.tie(0);
        string s;
        cin >> s;
        string temp;
        if (s[s.size() - 1] == 'r')
        {
                cout << "er" << endl;
        }
        else
        {
                cout << "ist" << endl;
        }
        return 0;
}

B - Mongeness

思路分析:

代码如下:

#include <bits/stdc++.h>
using namespace std;
const int maxn = 60;
int a[maxn][maxn];
int main()
{
        ios::sync_with_stdio(0);
        cin.tie(0);
        cout.tie(0);
        int h, w;
        cin >> h >> w;
        for (int i = 1; i <= h; i++)
        {
                for (int j = 1; j <= w; j++)
                {
                        cin >> a[i][j];
                }
        }
        bool flag = 0;
        for (int i = 1; i < h; i++)
        { //i1
                for (int j = i + 1; j <= h; j++)
                { //i2
                        for (int k = 1; k < w; k++)
                        { //j1
                                for (int x = k + 1; x <= w; x++)
                                { //j2
                                        int x1 = a[i][k] + a[j][x];
                                        int x2 = a[j][k] + a[i][x];
                                        if (x1 > x2)
                                        {
                                                flag = 1;
                                                break;
                                        }
                                        else
                                                continue;
                                }
                                if (flag)
                                        break;
                        }
                        if (flag)
                                break;
                }
                if (flag)
                        break;
        }
        if (flag)
        {
                cout << "No" << endl;
        }
        else
                cout << "Yes" << endl;
        return 0;
}

C - Triangle?

思路分析:

代码如下:

#include <bits/stdc++.h>
using namespace std;
const int maxn = 500;
int x[maxn], y[maxn];
const double eps = 1e-6;
int main()
{
        ios::sync_with_stdio(0);
        cin.tie(0);
        cout.tie(0);
        int n;
        cin >> n;
        for (int i = 1; i <= n; i++)
        {
                cin >> x[i] >> y[i];
        }
        long long ans = n * (n - 1) * (n - 2) / (3 * 2);
        for (int i = 1; i < n - 1; i++)
        {
                //1
                for (int j = i + 1; j < n; j++)
                {
                        //2
                        for (int k = j + 1; k <= n; k++)
                        {
                                //3
                                int x1 = x[i], y1 = y[i];
                                int x2 = x[j], y2 = y[j];
                                int x3 = x[k], y3 = y[k];
                                if (x3 * y2 - x1 * y2 - x3 * y1 == x2 * y3 - x2 * y1 - x1 * y3)
                                        ans--;
                        }
                }
        }
        cout << ans << endl;
        return 0;
}

D - 8 Puzzle on Graph

思路分析:

代码如下:

#include <bits/stdc++.h>
using namespace std;
const int maxn = 50;
vector<int> e[maxn];
map<string, int> mp;
int main()
{
        string s = "999999999";
        ios::sync_with_stdio(0);
        cin.tie(0);
        cout.tie(0);
        int m;
        cin >> m;
        for (int i = 1; i <= m; i++)
        {
                int u, v;
                cin >> u >> v;
                e[u].push_back(v);
                e[v].push_back(u);
        }
        for (int i = 1; i <= 8; i++)
        {
                int x;
                cin >> x;
                s[x - 1] = i + '0';
        }
        mp[s] = 0;
        queue<string> q;
        q.push(s);
        while (!q.empty())
        {
                string s = q.front();
                q.pop();
                int u = 0;
                for (int i = 1; i <= 9; i++)
                {
                        if (s[i - 1] == '9')
                        {
                                u = i;
                        }
                }
                for (auto x : e[u])
                {
                        string t = s;
                        swap(t[u - 1], t[x - 1]);
                        //每一个相邻的边都操作一次
                        if (mp.count(t))
                                continue;
                        //出现过了
                        mp[t] = mp[s] + 1;
                        q.push(t);
                }
        }
        if (mp.count("123456789") == 0)
        {
                cout << -1 << endl;
        }
        else
        {
                cout << mp["123456789"] << endl;
        }
        return 0;
}

E - Integers on Grid

思路分析:

代码如下:

#include <bits/stdc++.h>
using namespace std;
const int maxn = 2e5 + 10;
map<int, vector<int>> mp;
int r[maxn];
int c[maxn];
int val[maxn];
int dp[maxn];
int rmax[maxn];
int cmax[maxn];
int main()
{
        ios::sync_with_stdio(0);
        cin.tie(0);
        cout.tie(0);
        int h, w, n;
        cin >> h >> w >> n;
        for (int i = 1; i <= n; i++)
        {
                cin >> r[i] >> c[i] >> val[i];
                mp[val[i]].push_back(i);
        }
        for (auto it = mp.rbegin(); it != mp.rend(); it++)
        {
                for (auto i : it->second)
                {
                        dp[i] = max(rmax[r[i]], cmax[c[i]]);
                }
                for (auto i : it->second)
                {
                        rmax[r[i]] = max(rmax[r[i]], dp[i] + 1);
                        cmax[c[i]] = max(cmax[c[i]], dp[i] + 1);
                }
        }
        for (int i = 1; i <= n; i++)
        {
                cout << dp[i] << endl;
        }
        return 0;
}

标签:AtCoder,cout,Beginner,int,最大值,cin,maxn,tie,224
来源: https://www.cnblogs.com/csu-yuuki/p/15450823.html