首页 > 编程语言 >2023年中国高校计算机大赛-团队程序设计天梯赛(GPLT)上海理工大学校内选拔赛(同步赛)

2023年中国高校计算机大赛-团队程序设计天梯赛(GPLT)上海理工大学校内选拔赛(同步赛)

时间:2023-09-30 13:22:11浏览次数:52  
标签:10 return cout int ans cin 上海理工大学 2023 GPLT

A. A Xor B Problem(计数)

输入

5
1 1 2 2 3

输出

9

说明

点击查看代码
#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(false);cin.tie(0),cout.tie(0)
#define int long long

using namespace std;

const int N = 2e5 + 10;

unordered_map<int, int> mp;
int ans, s, n, x;

void solve()
{
    cin >> n;
    while(n --)
    {
        cin >> x;
        s += mp[x] * mp[x];
        mp[x] ++;
        ans += mp[x] * mp[x];
    }
    cout << ans - s << '\n';
}

signed main()
{
    IOS;
    int _ = 1;
//     cin >> _;
    while(_ --)
        solve();
    return _ ^ _;
}

B. 吃苹果(贪心)

输入

4 3
3 1
4 5
2 3
1 5

输出

16

说明

对于 10% 的数据,1≤n≤10。
对于 40% 的数据,\(1≤n≤10^4\) 。
对于 100% 的数据,\(1≤k≤n≤10^5,1≤a_i,b_i≤10^4\)。

点击查看代码
#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(false);cin.tie(0),cout.tie(0)
#define int long long

using namespace std;

const int N = 2e5 + 10;

int n, m, ans;
int a[N];
struct node
{
    int x, y, s;
}p[N];

bool cmp(node a, node b)
{
    return a.s > b.s;
}

void solve()
{
    cin >> n >> m;
    for(int i = 0; i < n; i ++)
        cin >> p[i].x >> p[i].y, p[i].s = p[i].y - p[i].x;
    sort(p, p + n, cmp);
    for(int i = 0; i < n; i ++)
    {
        if(m) ans += p[i].y, m --;
        else ans += p[i].x;
    }
    cout << ans << '\n';
}

signed main()
{
    IOS;
    int _ = 1;
//     cin >> _;
    while(_ --)
        solve();
    return _ ^ _;
}

C. n皇后问题(模拟)

输入

2 4
1 1
1 2
2 1
2 2

输出

Yes
No
No
No

说明

点击查看代码
#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(false);cin.tie(0),cout.tie(0)
#define int long long

using namespace std;

const int N = 1e7 + 10;

int n, m;
int l[N], r[N], p[N], up[N];

void solve()
{
    cin >> n >> m;
    while(m --)
    {
        int x, y;
        cin >> x >> y;
        if(!l[x]&&!r[y]&&!p[x + n + y]&&!up[2 * n + x - y])
        {
            cout << "Yes\n";
            l[x] = 1, r[y] = 1;
            p[x + y + n] = 1;
            up[2 * n + x - y] = 1;
        }
        else cout << "No\n";
    }
}

signed main()
{
    IOS;
    int _ = 1;
//     cin >> _;
    while(_ --)
        solve();
    return _ ^ _;
}

D. 分苹果(模拟)

输入

4
0 1 0
1 0 0
1 1
1 -1
-1 1
-1 -1

输出

1 1 1 1

说明

对于 10% 的数据,\(1≤n≤10,−10 ^2≤Ae,Be,Ce,Ar,Br,Cr≤10^2,−10^3≤x,y≤10 ^3\)。
对于 40% 的数据,\(1≤n≤10^4,−10^4≤Ae,Be,Ce,Ar,Br,Cr≤10^4,−10^5≤x,y≤10^5\)。
对于 100% 的数据,\(1≤n≤10^5,−10^8≤Ae,Be,Ce,Ar,Br,Cr≤10^8,−10^9≤x,y≤10^9,(Ae∣Be)!=0,(Ar∣Br)!=0\)。

点击查看代码
#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(false);cin.tie(0),cout.tie(0)
#define int long long

using namespace std;

const int N = 2e5 + 10;

int a1, a2, b1, b2, c1, c2;
int s[10], n;

bool get1(int x, int y)
{
    return a1 * x + b1 * y + c1 > 0;
}

bool get2(int x, int y)
{
    return a2 * x + b2 * y + c2 > 0;
}

void solve()
{
    cin >> n;
    cin >> a1 >> b1 >> c1 >> a2 >> b2 >> c2;
    while(n --)
    {
        int x, y;
        cin >> x >> y;
        if(get1(x, y)&&get2(x, y))
            s[1] ++;
        else if(!get1(x, y)&&get2(x, y))
            s[2] ++;
        else if(!get1(x, y)&&!get2(x, y))
            s[3] ++;
        else s[4] ++;
    }
    sort(s + 1, s + 5);
    for(int i = 1; i < 5; i ++)
        cout << s[i] << ' ';
}

signed main()
{
    IOS;
    int _ = 1;
//     cin >> _;
    while(_ --)
        solve();
    return _ ^ _;
}

E. 完形填空(概率dp)

输入

4
10 20 30 40
40 30 20 10
10 40 20 30
30 10 40 20

输出

160

说明

对于30% 的数据,n=4
对于 60% 的数据,1≤n≤20
对于 100% 的数据,1≤n≤100

点击查看代码
#include<iostream>
#include<cstring>

using namespace std;

const int N = 26, M = 110;

int dp[M][N][N][N][N];
int A[M], B[M], C[M], D[M];
int n;

int dfs(int n, int a, int b, int c, int d)
{
	if(n == 0) return 0;
	if(a < 0||b < 0||c < 0||d < 0) return -1e9;
	int &ans = dp[n][a][b][c][d];
	if(ans) return ans;
	if(a) ans = max(ans, A[n] + dfs(n - 1, a - 1, b, c, d));
	if(b) ans = max(ans, B[n] + dfs(n - 1, a, b - 1, c, d));
	if(c) ans = max(ans, C[n] + dfs(n - 1, a, b, c - 1, d));
	if(d) ans = max(ans, D[n] + dfs(n - 1, a, b, c, d - 1));
	return ans;
}

int main()
{
	cin >> n;
	for(int i = 1; i <= n; i ++)
		cin >> A[i] >> B[i] >> C[i] >> D[i];
	cout << dfs(n, n / 4, n / 4, n / 4, n / 4) << endl;
	return 0;
}

G. A Xor B Problem again(计数)

输入

5
1 1 2 2 3

输出

8

说明

点击查看代码
#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(false);cin.tie(0),cout.tie(0)
#define int long long

using namespace std;

const int N = 2e5 + 10;

int sum[N], val[N];
int vis[N];
int n, ans, a[N];
int bin[N];

void solve()
{
    cin >> n;
    bin[0] = 1;
    for(int i = 1; i < 19; i ++) bin[i] = bin[i - 1] << 1;
    for(int i = 1; i <= n; i ++)
        cin >> a[i], sum[a[i]] ++;
    for(int i = 1; i <= n; i ++)
    {
        int v = 0;
        for(int j = 0; j < 17; j ++)
            if((a[i] & bin[j]) == 0)
                v |= bin[j];
        if(vis[v]) ans += val[v];
        else
        {
            for(int s = v; s; s = v&(s - 1))
                val[v] += sum[s];
            val[v] += sum[0];
            ans += val[v];
            vis[v] = 1;
        }
    }
    cout << ans << '\n';
}

signed main()
{
    IOS;
    int _ = 1;
//     cin >> _;
    while(_ --)
        solve();
    return _ ^ _;
}

H. 摘苹果(线段树)

输入

5 5
1 10 100 1000 10000
2 1 5
3 1 5
1 1 5
2 1 5
3 1 5

输出

2
11111
3
7405

说明

对于 100% 的数据,\(1≤n≤10^5 ,1≤m≤10^5 , 1≤a_i ≤10^9 ,1≤op≤3,1≤l≤r≤n\)。

点击查看代码
#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(false);cin.tie(0),cout.tie(0)
#define int long long

using namespace std;

const int N = 1e5 + 10;

struct node
{
    int l, r;
    int s, e;
    bool f;
}tr[N << 2];
int n, m;
int a[N];

void pushup(int u)
{
    tr[u].s = tr[u << 1].s + tr[u << 1 | 1].s;
    tr[u].e = tr[u << 1].e + tr[u << 1 | 1].e;
    tr[u].f = tr[u << 1].f || tr[u << 1 | 1].f;
}

void build(int u, int l, int r)
{
    if(l == r) tr[u] = {l, r, a[l], a[l] < 100, a[l] > 9};
    else
    {
        tr[u] = {l, r};
        int mid = l + r >> 1;
        build(u << 1, l, mid);
        build(u << 1 | 1, mid + 1, r);

        pushup(u);
    }
}

void modify(int u, int l, int r)
{
    if(!tr[u].f) return ;
    if(tr[u].l == tr[u].r)
    {
        tr[u].s -= (tr[u].s + 2) / 3;
        tr[u].e = tr[u].s < 100;
        tr[u].f = tr[u].s > 9;
    }
    else
    {
        int mid = tr[u].l + tr[u].r >> 1;
        if(l <= mid) modify(u << 1, l, r);
        if(r > mid) modify(u << 1 | 1, l, r);

        pushup(u);
    }
}

int query(int u, int l, int r, int f)
{
    if(tr[u].l >= l&&tr[u].r <= r)
    {
        if(f == 2) return tr[u].e;
        return tr[u].s;
    }
    else
    {
        int mid = tr[u].l + tr[u].r >> 1;
        int s = 0;
        if(l <= mid) s += query(u << 1, l, r, f);
        if(r > mid) s += query(u << 1 | 1, l, r, f);

        return s;
    }
}

void solve()
{
    cin >> n >> m;
    for(int i = 1; i <= n; i ++) cin >> a[i];
    build(1, 1, n);

    int f, l, r;
    while(m --)
    {
        cin >> f >> l >> r;
        if(f == 1) modify(1, l, r);
        else cout << query(1, l, r, f) << '\n';
    }
}

signed main()
{
    IOS;
    int _ = 1;
//     cin >> _;
    while(_ --)
        solve();
    return _ ^ _;
}

标签:10,return,cout,int,ans,cin,上海理工大学,2023,GPLT
From: https://www.cnblogs.com/chfychin/p/17737751.html

相关文章

  • 20211325 2023-2024-1 《信息安全系统设计与实现(上)》第四周学习笔记
    202113252023-2024-1《信息安全系统设计与实现(上)》第四周学习笔记一、任务要求自学教材第7,8章,提交学习笔记(10分),评分标准如下1.知识点归纳以及自己最有收获的内容,选择至少2个知识点利用chatgpt等工具进行苏格拉底挑战,并提交过程截图,提示过程参考下面内容(4分)“我......
  • origin怎么下载-2023全新绿色中文版下载 安装包下载方式
    Origin最新版是一款功能强大的数据分析和绘图软件。这款软件内置了查询工具,用户可通过ADO访问数据库数据进行查询。它还为用户提供了多种模板效果供用户使用,不仅如此,它还支持定制。有需要的小伙伴快来系统城下载origin最新版软件使用吧。软件地址:看置顶贴安装教程1、将本站提供的文......
  • 2023-2024-1 20231327司宏林 《计算机基础与程序设计》第一周学习总结
    学期(2023-2024-1)20231327《计算机基础与程序设计》第1周学习总结作业信息这个作业属于哪个课程<班级的链接>(2023-2024-1-计算机基础与程序设计)这个作业要求在哪里<作业要求的链接>([https://edu.cnblogs.com/campus/besti/2023-2024-1-CFAP/homework/13009)这个作......
  • 2023-2024-1 20231308 《计算机基础与程序设计》第一周学习总结
    2023-2024-120231308《计算机基础与程序设计》第一周学习总结作业信息作业课程2023-2024-1-计算机基础与程序设计作业要求2023-2024-1计算机基础与程序设计第一周作业作业目标教材内容学习作业正文2023-2024-120231308《计算机基础与程序设计》第一周学习......
  • [春季测试 2023] 密码锁 题解
    题目传送门闲话duliu题,写了10k。题意形式化地,对于\(1\leqi\leqk\),定义密码锁第\(i\)行的松散度为\[c(i)=\max\limits_{j=1}^na_{i,j}-\min\limits_{j=1}^na_{i,j}\]同时定义整个密码锁的松散度为\[C=\max\limits_{1\leqi\leq......
  • 2023-09-29-周五
    今天中秋节...是的...哈哈可还是很emo回望整整一天,,,好像还是没干什么月饼??这东西我好像吃了很多...都是实验室送的同时,,我想想...我还喝了7~8瓶东方树叶..........
  • 2023.9.29
    今天继续去试着做之前的一道题,但是写的exp报了一些奇怪的错,去查,然后尝试解决,再报新的错,再查,再尝试解决.......总之试了很久,最后发现可能是我当前Ubuntu版本的问题,于是又去找了个对应版本的Ubuntu,重新建了一个虚拟机,安装,配置pwn要用到的各种东西...搞了很久,今天没能做出一道题,明......
  • 20230928
    //accommodate,bargain,concession,consider,dicker,exception,figure,haggle,induce,minimum,practically,atasacrificeaccommodate-容纳Toaccommodatemeanstoprovideaplaceorspaceforsomeoneorsomething.Itcanalsorefertoadjustingorad......
  • 20230929
    //accommodate,bargain,concession,consider,dicker,exception,figure,haggle,induce,minimum,practically,atasacrificeaccommodate-容纳Toaccommodatemeanstoprovideaplaceorspaceforsomeoneorsomething.Itcanalsorefertoadjustingorad......
  • 2023.9.29——每日总结
    学习所花时间(包括上课):0h代码量(行):0行博客量(篇):1篇今天,上午陪同学去医院,下午休息;我了解到的知识点:休息明日计划:休息......