【补题/atccoder】Toyota Programming Contest 2024#7(AtCoder Beginner C ...

打印 上一主题 下一主题

主题 1757|帖子 1757|积分 5271

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
A、买笔


   思路:
  输入红绿蓝三只笔价格,再输入不喜欢颜色,
  输出除不喜欢颜色笔以外最低价格
  代码如下:
  1. #include <iostream>
  2. #include <algorithm>
  3. using namespace std;
  4. int main()
  5. {
  6.         int r, g, b;
  7.         cin >> r >> g >> b;
  8.         string s;
  9.         cin >> s;
  10.         if (s == "Red")
  11.         {
  12.                 if (g < b) cout << g;
  13.                 else cout << b;
  14.         }
  15.         else if (s == "Green")
  16.         {
  17.                 if (r < b)cout << r;
  18.                 else cout << b;
  19.         }
  20.         else if (s == "Blue")
  21.         {
  22.                 if (r < g)cout << r;
  23.                 else cout << g;
  24.         }
  25.         return 0;
  26. }
复制代码
B、判断是否为直角三角形


   题目本质:
  给定不共线的三点,判断他们是否可以形成直角三角形。
  注意:必要用long long范例。
  1. #include<iostream>
  2. #include <cmath>
  3. using namespace std;
  4. int main() {
  5.         int a1, a2, b1, b2, c1, c2;
  6.         cin >> a1 >> a2 >> b1 >> b2 >> c1 >> c2;
  7.         int ab = abs(a1 - b1) * abs(a1 - b1) + abs(a2 - b2) * abs(a2 - b2);
  8.         int ac = abs(a1 - c1) * abs(a1 - c1) + abs(a2 - c2) * abs(a2 - c2);
  9.         int        bc = abs(c1 - b1) * abs(c1 - b1) + abs(c2 - b2) * abs(c2 - b2);
  10.         if (ab + ac == bc || ab + bc == ac || ac + bc == ab) cout << "Yes";
  11.         else cout << "No";
  12.         return 0;
  13. }
复制代码
C、和值为0


数据输入/输出
   样例1:
  输入:
  3
3 5
-4 1
-2 3
输出:
  Yes
4 -3 -1 (结果不唯一)
 
  样例2:
  输入:
  3
1 2
1 2
1 2
输出:
  No
    题目本质:
  给定L,X,R三个数组,已知L,R的数据,而且L <= X <= R
  思路:
  设s_min为L的和,s_max为R的总和,当s_min大于0大概s_max小于0,不大概存在
  然后我们给X初始化为L,此时X的和为s(等于s_min),然后用dif 存下 (R - L,-s)的较小值。
  当s<0时,则dif则增长X,间接增长s的值
  当 s >0,则dif则减少X,间接减少s的值
  1. #include <iostream>
  2. #include <algorithm>
  3. #include <vector>
  4. using namespace std;
  5. typedef long long LL;
  6. LL s_min, s_max;
  7. int main()
  8. {
  9.         int n;
  10.         cin >> n;
  11.         vector<int> L(n), R(n), X(n);
  12.         for (int i = 0; i < n; i++)
  13.         {
  14.                 cin >> L[i] >> R[i];
  15.                 s_min += L[i];
  16.                 s_max += R[i];
  17.         }
  18.        
  19.         if (s_min > 0 || s_max < 0) cout << "No" << "\n";
  20.         else
  21.         {
  22.                 cout << "Yes" << "\n";
  23.                 for (int i = 0; i < n; i++) X[i] = L[i]; //给x先赋初值
  24.                 LL s = s_min; //s一定为负数
  25.                 for (int i = 0; i < n; i++) {
  26.                         if (s == 0) break;
  27.                         //由于R[i] - L[i] >=0
  28.                         //s为负数,X[i]增加,那么s也增加
  29.                         LL dif = min((LL)R[i] - L[i], -s);
  30.                         X[i] += dif;
  31.                         s += dif;
  32.                 }
  33.                 for (int i = 0; i < n; i++)cout << X[i] << " ";
  34.         }
  35.         return 0;
  36. }
复制代码
D、最短路径


   样例1输入:
  3 3
1 2 3
1 2 1
1 3 6
2 3 2
输出:4 9
 
  样例2输入:
  2 1
0 1
1 2 3
输出:4
  
  样例3输入:
  5 8
928448202 994752369 906965437 942744902 907560126
2 5 975090662
1 2 908843627
1 5 969061140
3 4 964249326
2 3 957690728
2 4 942986477
4 5 948404113
1 3 988716403
输出:2832044198 2824130042 4696218483 2805069468
    题目本质就是给定n个点,m条边,
  先输入每个点的自身权值,然后再输入m条边的权值。输入时不大概输入同一边的不同权值
  如样例一中,1到2的最小权值为 1 + 1 + 2 = 4;
  1到3的最小权值为 4 + 3 + 2 = 9;
  ’思路:
  可以用better_dijkstra()来写,
  1. #include <iostream>
  2. #include <algorithm>
  3. #include <cstring>
  4. #include <vector>
  5. #include <queue>
  6. using namespace std;
  7. const int N = 2e5 + 10;
  8. typedef long long ll;
  9. typedef pair<ll, int> PII; //权值和终点
  10. ll dist[N], a[N];// 存储1号点到每个点的最短距离,每个点自身权值
  11. int n, m;
  12. struct Node {
  13.         int y, val; //终点和权值
  14. };
  15. vector<Node> f[N];
  16. void  better_dijkatra(int st)
  17. {
  18.         memset(dist, 0x3f3f, sizeof dist);
  19.         priority_queue<PII, vector<PII>, greater<PII>> q;
  20.         dist[st] = a[st];
  21.         q.push({ dist[st],st });
  22.         while (!q.empty())
  23.         {
  24.                 ll d = q.top().first, u = q.top().second; //终点和权值
  25.                 q.pop();
  26.                 if (d > dist[u]) continue;
  27.                 for (auto edge : f[u]) //遍历当前终点所连接的边
  28.                 {
  29.                         ll v = edge.y, val = edge.val;
  30.                         if (dist[u] + val + a[v] < dist[v])
  31.                         {
  32.              //当前两点的权值等于边权+之前最短点权值,加终点自身权值
  33.                                 dist[v] = dist[u] + val + a[v];
  34.                                 q.push({ dist[v], v });
  35.                         }
  36.                 }
  37.         }
  38. }
  39. int main()
  40. {
  41.         cin >> n >> m;
  42.         for (int i = 1; i <= n; i++)  cin >> a[i];
  43.         while (m--)
  44.         {
  45.                 int u, v, b;
  46.                 cin >> u >> v >> b;
  47.                 f[u].push_back({ v,b });
  48.                 f[v].push_back({ u,b });
  49.         }
  50.         better_dijkatra(1); //从1号点开始
  51.         for (int i = 2; i <= n; i++) cout << dist[i] << " ";
  52.         return 0;
  53. }
复制代码
E、盘算算术子序列的数量


   样例1输入:
  5
1 2 3 2 3
  输出:5 10 3 0 0
 
  样例2输入:
  4
1 2 3 4
  输出:4 6 2 1
 
  样例3输入:
  1
100
  输出:1
    题目本质:
  相称于对于n个数字,输出长度为i(1<=i<=n)的子序列个数,对于子序列要求其相应次序不变,好比样例1中
  长度为1的子序列:(1)、(2)、(3)、(4)、(5)
  长度为2的子序列:长度为2的子序列都是算术子序列
  长度为3的子序列:(1,2,3)、(1,2,5)、(1,4,5)
  长度为4的子序列:0
  长度为5的子序列:0
  注意:
  子序列:是通过从原序列删除零个或多个元素并在不改变次序的情况下分列其余元素而获得的序列
  算术序列:是一个数字列表,其中的一连项相差一个常数,即共同的差(也就是雷同于等差数列)
  1. #include <iostream>
  2. #include <cstdio>
  3. #include <cstring>
  4. using namespace std;
  5. typedef long long ll;
  6. const ll N = 85, M = 998244353;
  7. ll n, a[N], f[N][N][N];
  8. int main() {
  9.         cin >> n;
  10.         for (int i = 1; i <= n; i++) cin >> a[i];
  11.         for (int i = 1; i <= n; i++) {
  12.                 for (int j = 1; j < i; j++)
  13.                         f[i][j][2] = 1; //初始化
  14.         }
  15.         cout << n << ' ';
  16.         ll ans = 0;
  17.         for (int l = 2; l <= n; l++) {
  18.                 ll as = 0;
  19.                 for (int i = 2; i <= n; i++) {
  20.                         for (int j = 1; j < i; j++) {
  21.                                 for (int k = 1; k < j; k++) {
  22.                                         if (a[i] - a[j] == a[j] - a[k]) {
  23.                                                 f[i][j][l] += f[j][k][l - 1];
  24.                                                 f[i][j][l] %= M;
  25.                                         }
  26.                                 }
  27.                                 as += f[i][j][l], as %= M;
  28.                         }
  29.                 }
  30.                 cout << as << ' ';
  31.                 //ans += as;
  32.         }
  33.         //cout << ans << "\n";
  34.         return 0;
  35. }
复制代码




免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

兜兜零元

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表