2019 山东省大学生程序设计竞赛

A. Calandar

纯模拟吧(感觉我做麻烦了(?),

就是如果问的是未来的日期,就用相隔天数取模后加上这天的星期,

如果问的是曾经的,就用这天的星期减去相隔天数的取模后的数,因为是减法,记得加模数

#include <bits/stdc++.h>
#define int long long
#define endl '\n' using namespace std; signed main() {
ios::sync_with_stdio(false);
cin.tie(nullptr); unordered_map<string,int> cal;
unordered_map<int,string> ca;
cal["Monday"] = 1;
cal["Tuesday"] = 2;
cal["Wednesday"] = 3;
cal["Thursday"] = 4;
cal["Friday"] = 5;
ca[1] = "Monday";
ca[2] = "Tuesday";
ca[3] = "Wednesday";
ca[4] = "Thursday";
ca[0] = "Friday"; int T;
cin >> T;
while (T--) {
int y1,y2,m1,m2,d1,d2;
string s;
cin >> y1 >> m1 >> d1 >> s >> y2 >> m2 >> d2;
m1--,m2--;
int sum = 0;
if(y1 > y2){
int s1 = m1 * 30 + d1 + 360 , s2 = m2 * 30 + d2;
sum = (cal[s] - (s1 - s2) % 5 + 5) % 5 ;
}else if(y1 < y2){
int s1 = m1 * 30 + d1 , s2 = m2 * 30 + d2 + 360;
sum = (cal[s] + (s2 - s1) % 5) % 5 ;
}else {
int s1 = m1 * 30 + d1 , s2 = m2 * 30 + d2;
if(s1 > s2){
sum = (cal[s] - (s1 - s2) % 5 + 5) % 5 ;
}else{
sum = (cal[s] + (s2 - s1) % 5) % 5 ;
}
}
cout << ca[sum] << endl;
}
return 0;
}

C. Wandering Robot

先跑一轮算出最后所在的位置,然后算\(k-1\)次即最后一次移动的起点,最后再跑一轮

#include <bits/stdc++.h>
#define int long long
#define endl '\n' using namespace std;
typedef pair<int,int> PII; signed main() {
ios::sync_with_stdio(false);
cin.tie(nullptr);
int t = 1;
cin >> t;
while (t--) {
int n, k;
cin >> n >> k;
string s;
cin >> s;
int MaxX,Maxy, EndX,EndY, ans = 0,x = 0,y = 0;
for(int i = 0;i < n;i ++){
if(s[i] == 'R') x++;
else if(s[i] == 'L') x--;
else if(s[i] == 'U') y++;
else y--; int val = abs(x) + abs(y);
ans = max(ans, val); }
x *= (k - 1), y *= (k - 1);
if(k > 1){
for(int i = 0;i < n;i ++){
if(s[i] == 'R') x++;
else if(s[i] == 'L') x--;
else if(s[i] == 'U') y++;
else y--;
int val = abs(x) + abs(y);
ans = max(ans, val);
}
} cout << ans << endl; }
return 0;
}

D. Game on a Graph

连通图最少需要 \((n-1)\)条边,因此最多可以操作 \((m-(n-1))\) 次,输的人就是 \((m-(n -1)) \bmod k\)。考虑到读入,复杂度 \(\mathcal{O}(k+m)\)。

#include <bits/stdc++.h>
#define int long long using namespace std; signed main(){
ios::sync_with_stdio(false);
cin.tie(nullptr); int T;
cin >> T;
while(T--){
int n,m,k;
string s;
cin >> k >> s;
cin >> n >> m;
for(int i = 0,l,r;i < m;i ++)
cin >> l >> r;
if(s[(m - (n - 1)) % k] == '1') cout << 2 << '\n';
else cout << '1' << '\n';
} return 0;
}

F. Stones in the Bucket

考虑都往中间靠,如果总数不是\(s\)的倍数,就用操作\(1\)丢掉几个,然后都往中间靠,取多补少

#include <bits/stdc++.h>
#define int long long using namespace std;
typedef pair<int,int> PII; signed main(){
ios::sync_with_stdio(false);
cin.tie(nullptr); int T;
cin >> T;
while(T--){
int n,sum = 0;
cin >> n;
vector<int> a(n);
for(auto &i : a){
cin >> i;
sum += i;
} int tag = sum / n, ans = sum % n;
for(auto i : a)
ans += max(tag - i, 0ll);
cout << ans << '\n';
} return 0;
}

H. Tokens on the Segments

如果我们让更多的线段被标记,那同一个点上应该选择右端点最小的段,可以用堆来模拟这个过程

每次我们取了一点后,把后面的段又放进堆里,如此循环(貌似这题数据很水,暴力的也过了

#include <bits/stdc++.h>
#define int long long using namespace std;
typedef pair<int,int> PII; struct Node{
int l,r;
Node(){}
Node(int l,int r) : l(l),r(r){}
bool operator < (const Node& s)const{
if(s.l == l) return r > s.r;
return l > s.l;
}
}; signed main(){
ios::sync_with_stdio(false);
cin.tie(nullptr); int T;
cin >> T;
while(T--){
int n;
cin >> n; priority_queue<Node> Q;
for(int i = 0;i < n;i ++){
int l,r;
cin >> l >> r;
Q.push(Node(l,r));
} int now = 0, ans = 0;
while(Q.size()){
auto [l,r] = Q.top();
Q.pop(); if(l <= now && l + 1 <= r){
Q.push(Node(l + 1, r));
continue;
}
if(l > now){
ans ++;
now = l;
}
}
cout << ans << '\n';
} return 0;
}

L. Median

思路就是去跑\(dfs\)或\(bfs\)计算出每个数大于多少和小于多少,如果大于的数超过了\(\lfloor\frac{n}{2}\rfloor\)或者小于的数超过了\(\lfloor\frac{n}{2}\rfloor\)都说明这个数不可能为中位数,另外如果在跑\(dfs\)或\(bfs\)的过程中出现了环,就是\(a>b,b>c,c>a\)这种,则无解

#include <bits/stdc++.h>
#define int long long using namespace std;
typedef pair<int,int> PII; void solve(){
int n,m;
cin >> n >> m;
vector<int> pre(n + 1),nxt(n + 1),g[n + 1];
for(int i = 0;i < m;i ++){
int x,y;
cin >> x >> y;
g[x].emplace_back(y);
} vector<int> vis(n + 1);
auto bfs = [&](int x){
queue<int> Q;
Q.push(x), vis[x] = x; while(Q.size()){
auto u = Q.front();
Q.pop(); for(auto i : g[u]){
if(i == x) return false;
if(vis[i] == x) continue; Q.push(i);
vis[i] = x;
pre[i]++,nxt[x]++;
}
}
return true;
}; for(int i = 1;i <= n;i ++){
if(!bfs(i)){
cout << string(n,'0') << '\n';
return ;
}
} for(int i = 1;i <= n;i ++){
if(pre[i] * 2 <= n && nxt[i] * 2 <= n)
cout << '1';
else
cout << '0';
}
cout << '\n';
return ;
} signed main(){
ios::sync_with_stdio(false);
cin.tie(nullptr); int T;
cin >> T;
while(T--){
solve();
} return 0;
}

M. Sekiro

\(n=1\)时就会一直循环了,因此\(n=1\)时退出即可

#include <bits/stdc++.h>
#define int long long using namespace std; signed main(){
ios::sync_with_stdio(false);
cin.tie(nullptr); int T;
cin >> T;
while(T--){
int n,m;
cin >> n >> m;
for(int i = 1;i <= m;i ++){
if(n > 1) n = (n + 1) >> 1;
else break;
}
cout << n << '\n';
}
return 0;
}

SMU Summer 2023 Contest Round 9(2019 山东省大学生程序设计竞赛)的更多相关文章

  1. [BFS,A*,k短路径] 2019中国大学生程序设计竞赛(CCPC) - 网络选拔赛 path (Problem - 6705)

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=6705 path Time Limit: 2000/2000 MS (Java/Others)    Mem ...

  2. [贪心,dp] 2019中国大学生程序设计竞赛(CCPC) - 网络选拔赛 Fishing Master (Problem - 6709)

    题目:http://acm.hdu.edu.cn/showproblem.php?pid=6709 Fishing Master Time Limit: 2000/1000 MS (Java/Othe ...

  3. 2019中国大学生程序设计竞赛(CCPC) - 网络选拔赛(8/11)

    $$2019中国大学生程序设计竞赛(CCPC)\ -\ 网络选拔赛$$ \(A.\hat{} \& \hat{}\) 签到,只把AB都有的位给异或掉 //#pragma comment(lin ...

  4. 【赛后总结+部分题解】2019中国大学生程序设计竞赛(CCPC) - 网络选拔赛

    赛后总结: T:今天状态一般,甚至有点疲惫.然后12点比赛开始,和队友开始看题,从最后往前面看,发现数学题公式看不懂.然后发现队友已经双开做1001和1006了,我看着1007有人A,开始做1007. ...

  5. 2019河北省大学生程序设计竞赛(重现赛) L题-smart robot(深度优先搜索)

    题目链接:https://ac.nowcoder.com/acm/contest/903/L 题意:给你 n * n的方阵,你可以从任意一个数字开始走,可以走上下左右四个方向,走过的数字会被拼合,拼合 ...

  6. 2019河北省大学生程序设计竞赛(重现赛)B 题 -Icebound and Sequence ( 等比数列求和的快速幂取模)

    题目链接:https://ac.nowcoder.com/acm/contest/903/B 题意: 给你 q,n,p,求 q1+q2+...+qn 的和 模 p. 思路:一开始不会做,后面查了下发现 ...

  7. 2019河北省大学生程序设计竞赛(重现赛)J-舔狗 (拓扑排序)

    题目链接:https://ac.nowcoder.com/acm/contest/903/J 题意:给你 n 个舔狗和他喜欢的人,让你俩俩配对(只能和喜欢它的和它喜欢的),求剩下的单身狗数量. 思路: ...

  8. Contest - 中南大学第六届大学生程序设计竞赛(Semilive)

    题1:1160十进制-十六进制 注意他给的数据范围 2^31,int是 2^31-1 #include<iostream> using namespace std; int main() ...

  9. 2019中国大学生程序设计竞赛(CCPC) - 网络选拔赛

    传送门 A.^&^ 题意: 找到最小的正数\(C\),满足\((A\ xor\ C)\&(B\ xor \ C)\)最小. 思路: 输出\(A\&B\)即可,特判答案为0的情况 ...

  10. 【2019中国大学生程序设计竞赛-女生专场】C - Function

    原题 韦神提供的思路orz 首先一个显然的性质,所有的c可以提出来,方程变成ax^2+bx的形式 因为x的值是离散的,而m的值又不大 所以一开始让x都为1(注意!x是正整数),然后每次挑一个x让他加一 ...

随机推荐

  1. DPO: Direct Preference Optimization 直接偏好优化(学习笔记)

    学习参考:链接1   一.为什么要提出DPO 在之前,我们已经了解到基于人类反馈的强化学习RLHF分为三个阶段:全监督微调(SFT).奖励模型(RM).强化学习(PPO).但是RLHF面临缺陷:RLH ...

  2. SQLCel匹配原数据信息,更新原数据所有信息并插入新数据的过程

    使用SQLCel高效率(速度快,数据完整)的解决了我领导提的问题 "如何更新数据库中原有的数据并插入新的订单数据" 过程如下: 思路:使用字段匹配和修改字段即可解决问题,用时3分钟 ...

  3. [UG 二次开发 python] 导出BOM表(包含图片)

    只导出最底层的零件,零件的属性已经设置好,零件的截图生成后,放在零件的同一个文件夹下 用到了 xlsxwriter # nx: threaded # 导出BOM表 __version__ = &quo ...

  4. Yuno loves sqrt technology I 题解

    申明:由于本人卡常技艺不佳,本题解复杂度正确但无法通过 首先分块,然后考虑分开计算贡献维护,看下面一张图: 我们将贡献拆分为 \(ans(A) + ans(B) + ans(C) + ans(AB) ...

  5. javascript的内存(垃圾)回收机制?

    垃圾回收机制 1.js中的内存回收 在js中,垃圾回收器每隔一段时间就会找出那些不再使用的数据,并释放其所占用的内存空间. 以全局变量和局部变量来说,函数中的局部变量在函数执行结束后这些变量已经不再被 ...

  6. JavaScript --函数--手稿

  7. LabVIEW之项目文件结构透析

    代码的管理非常重要,LabVIEW本身自带很多代码管理工具.下面来剖析一个相对标准的小项目:

  8. salesforce零基础学习(一百四十)Record Type在实施过程中的考虑

    本篇参考: salesforce 零基础学习(二十九)Record Types简单介绍 https://help.salesforce.com/s/articleView?id=sf.customiz ...

  9. Python 标准类库-因特网数据处理之Base64数据编码

    该模块提供将二进制数据编码为可打印ASCII字符并将这种编码解码回二进制数据的功能.它为RFC 3548中指定的编码提供编码和解码功能.定义了Base16.Base32和Base64算法,以及事实上的 ...

  10. 很呆的一个问题:我的新项目又找不到mapper这个bean了

    1.选springboot版本 <properties> <java.version>8</java.version> <project.build.sour ...