尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

noip7

noip7
📅 发布时间:2026/6/19 16:43:09
11.13

11.13

挂分场。

t1

神秘淀粉质。

不想改了,反正noip不考(题解说的)。

赛时写了2h发现想假了,当场😡。

t2

简单构造。

但是挂分了。

每个球跳的次数求假了(不是这也能假)。

然后就挂了。

code

www
#include <bits/stdc++.h>
using namespace std;
int n, m;
vector<int> ans;signed main()
{freopen("atom.in", "r", stdin);freopen("atom.out", "w", stdout);ios::sync_with_stdio(0);cin.tie(0);cin >> n;int k = n - 1;if (k & 1)m = (1 + (k >> 1)) * (k >> 1) + (k / 2 + 1);elsem = (1 + (k >> 1)) * (k >> 1);cout << m << "\n";int cnt = 0, d = 1, tot, sum, lim = 1;int SUM = 0;for (int i = 1; i <= m; ++i){ans.clear();tot = 0, sum = 0;// if (i == m)//     cout << "d=" << d << "\n";if (cnt)sum += cnt, ans.emplace_back(cnt), ++tot;while (sum < k - d)sum += d, ans.emplace_back(d), ++tot;if (sum + d == k)ans.emplace_back(d), ++tot;cout << tot << ' ';for (auto y : ans)cout << y << ' ';cout << "\n";++cnt;if (cnt == lim){++d, cnt = 0;lim = (d > (k >> 1) ? k - d + 1 : d);// cout << "d=" << d << " lim=" << lim << "\n";}}// cout << SUM << "\n";return 0;
}

t3

树形dp(换根可以省)

dp一下回来的和不回来的。

注意是奇数减一还是偶数减一。

细节挺多,看代码吧。

code

#include <bits/stdc++.h>
#define int long long
using namespace std;
inline int read()
{int res = 0;char ch = getchar_unlocked();while (ch < '0')ch = getchar_unlocked();while (ch >= '0' && ch <= '9'){res = (res << 3) + (res << 1) + (ch ^ 48);ch = getchar_unlocked();}return res;
}const int maxn = 1e6 + 10;
int T, n;
int tot, to[maxn << 1], nxt[maxn << 1], h[maxn], val[maxn << 1];
inline void adde(int x, int y, int z)
{to[++tot] = y;nxt[tot] = h[x];h[x] = tot;val[tot] = z;
}int dp[maxn][2], sec[maxn], ans; // 0 no back / 1 go back
int fa[maxn];inline void dfs(int x, int f)
{for (int i = h[x]; i; i = nxt[i]){int y = to[i];if (y == f)continue;dfs(y, x);if (val[i] > 1)dp[x][1] += dp[y][1] + val[i] - (val[i] & 1);}for (int i = h[x]; i; i = nxt[i]){int y = to[i];if (y == f)continue;if (dp[x][1] - (val[i] > 1 ? dp[y][1] + val[i] - (val[i] & 1) : 0) + val[i] - (!(val[i] & 1)) + max(dp[y][0], dp[y][1]) >= dp[x][0]){sec[x] = dp[x][0];dp[x][0] = dp[x][1] - (val[i] > 1 ? dp[y][1] + val[i] - (val[i] & 1) : 0) + val[i] - (!(val[i] & 1)) + max(dp[y][0], dp[y][1]);fa[x] = y;}else if (sec[x] < dp[x][1] - (val[i] > 1 ? dp[y][1] + val[i] - (val[i] & 1) : 0) + val[i] - (!(val[i] & 1)) + max(dp[y][0], dp[y][1])){sec[x] = dp[x][1] - (val[i] > 1 ? dp[y][1] + val[i] - (val[i] & 1) : 0) + val[i] - (!(val[i] & 1)) + max(dp[y][0], dp[y][1]);}}
}inline void dfs1(int x, int f)
{ans = max(ans, max(dp[x][0], dp[x][1]));int reco0 = dp[x][0], reco1 = dp[x][1];for (int i = h[x]; i; i = nxt[i]){int y = to[i];if (y == f)continue;dp[x][0] = reco0, dp[x][1] = reco1;if (fa[x] == y){dp[x][0] = max(sec[x] - (val[i] > 1 ? val[i] + dp[y][1] - (val[i] & 1) : 0), dp[x][1] - max(dp[y][0], dp[y][1]) - val[i] + (val[i] & 1));}else{dp[x][0] = dp[x][0] - ((val[i] > 1 ? dp[y][1] + val[i] - (val[i] & 1) : 0));}if (val[i] > 1){dp[y][0] += dp[x][1] - dp[y][1];int tmp = dp[y][1];dp[y][1] = dp[x][1];dp[x][1] -= tmp + val[i] - (val[i] & 1);}if (dp[y][0] <= dp[y][1] - (val[i] > 1 ? val[i] + dp[x][1] - (val[i] & 1) : 0) + val[i] - (!(val[i] & 1)) + max(dp[x][1], dp[x][0])){sec[y] = dp[y][0];dp[y][0] = dp[y][1] - (val[i] > 1 ? val[i] + dp[x][1] - (val[i] & 1) : 0) + val[i] - (!(val[i] & 1)) + max(dp[x][1], dp[x][0]);fa[y] = x;}else if (sec[y] < dp[y][1] - (val[i] > 1 ? val[i] + dp[x][1] - (val[i] & 1) : 0) + val[i] - (!(val[i] & 1)) + max(dp[x][1], dp[x][0]))sec[y] = dp[y][1] - (val[i] > 1 ? val[i] + dp[x][1] - (val[i] & 1) : 0) + val[i] - (!(val[i] & 1)) + max(dp[x][1], dp[x][0]);dfs1(y, x);}
}signed main()
{freopen("plan.in", "r", stdin);freopen("plan.out", "w", stdout);ios::sync_with_stdio(0);cin.tie(0);cin >> T;while (T--){cin >> n;tot = 0;for (int i = 1; i <= n; i++)fa[i] = sec[i] = dp[i][0] = dp[i][1] = h[i] = 0;for (int i = 1, u, v, w; i < n; i++)cin >> u >> v >> w, adde(u, v, w), adde(v, u, w);dfs(1, 0);ans = 0;dfs1(1, 0);cout << ans << '\n';}return 0;
}

t4

不做简单题。


发现好像只要t1投入大量时间且得到分数不高就坠机了,之后的题满脑子都是暴力,根本无法有效思考。

本文来自博客园,作者:HS_fu3,转载请注明原文链接:https://www.cnblogs.com/HS-fu3/p/19228852

相关新闻

  • 在Windows系统置顶窗口不被Win+D快捷键影响
  • 点分树
  • HTTP请求走私漏洞介绍 - 实践

最新新闻

  • 宁波各区黄金回收测评 鄞州/海曙/江北变现哪家不压价 - 逸程
  • 2026深圳三大商圈黄金回收实测,逸程验金标准统一靠谱 - 逸程
  • K2.5技术解析:动态稀疏注意力与原生多模态架构
  • 2026杭州黄金回收避坑|认准商圈备案认证门店,杜绝虚高引流、到店压价 - 薛定谔的梨花猫
  • 石家庄黄金回收正规军在哪?2026实测门店星级榜,卖金前看一眼 - 奢侈品回收测评
  • 深度学习进阶(三十一)FlashAttention:IO 感知的精确注意力

日新闻

  • 5分钟掌握Python进化算法:Geatpy高性能优化工具完全指南
  • Microchip 24AA044 EEPROM选型与应用全指南:从参数解析到实战编程
  • 华为的鸿蒙到底有多牛?为什么称作遥遥领先?

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号