当前位置: 首页 > news >正文

第四周刷题小结

第一天

P1068 [NOIP2009 普及组] 分数线划定 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

思路:

这个题感觉不难,主要是用到了结构体cmp的自定义排序,但是还是错了一次,就是没注意到题目给的条件。

#include<iostream>
#include<algorithm>
using namespace std; 
struct node {int a;int b;
}k[5005];
bool cmp(const node q,const node w) {if (q.b == w.b) {return q.a < w.a;}return q.b > w.b;
}
int main() {int n, m;cin >> n >> m;for (int i = 0; i < n; i++) {cin >> k[i].a >> k[i].b;}int w = (m) * 1.5;sort(k, k+n, cmp);int flag = 0;for (int i = w; i < n; i++) {if (k[i].b == k[w - 1].b) {flag++;}else {break;}}cout << k[w - 1].b << ' ' << w + flag << endl;for (int i = 0; i < w+flag; i++) {cout << k[i].a << ' ' << k[i].b << endl;}
}

P1059 [NOIP2006 普及组] 明明的随机数 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

一个简单的去重排序,可以直接写出来,用桶排,也可以用c++的去重排序。

#include<iostream>
#include<algorithm>
using namespace std; 
int main() {int n;cin >> n;int a[1000];for (int i = 0; i < n; i++) {cin >> a[i];}sort(a, a + n);  // 排序int m = unique(a, a + n) - a;cout << m << endl;for (int i = 0; i < m; i++) {cout << a[i] << ' ';}
}

第二天

P1376 [USACO05MAR] Yogurt factory 机器工厂 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

思路:

这个题用贪心。统计最小代价的变量要用long long。

#include<iostream>
#include<algorithm>
using namespace std; 
int main() {int n, m;long long ans = 0;int minPrice = 0;cin >> n >> m;for (int i = 0; i < n; i++) {int a, b;cin >> a >> b;if (i == 0) {minPrice = a;}else {if (a < minPrice + m) {minPrice = a;}else {minPrice += m;}}ans = minPrice * b + ans;}cout << ans;
}

第三天

P1536 村村通 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

思路:

用并查集,每组数据的f数组需要重新赋值,for循环里的下标应从1开始。

#include<iostream>
#include<algorithm>
using namespace std; 
int f[1005];
int getf(int x) {if (x == f[x]) {return x;}else {return f[x] = getf(f[x]);}
}
void merge(int x, int y) {int t1 = getf(x);int t2 = getf(y);f[t1] = t2;}
int main() {int n, m;while (scanf("%d", &n)) {if (n == 0) {break;}cin >> m;for (int i = 1; i <= n; i++) {f[i] = i;}for(int i=0;i<m;i++) {int a, b;cin >> a >> b;merge(a, b);}int ans = 0;for (int i = 1; i <=n; i++) {if (getf(i) == i) {ans++;}}cout << ans - 1 << endl;}
}

第四天

P9810 [CCC 2015 S1] Zero That Out - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

思路:

用到vector容器的简单方法

c.clear()         移除容器中所有数据。

c.empty()         判断容器是否为空。

c.erase(pos)        删除pos位置的数据

c.erase(beg,end) 删除[beg,end)区间的数据

c.front()         传回第一个数据。

c.insert(pos,elem)  在pos位置插入一个elem拷贝

c.pop_back()     删除最后一个数据。

c.push_back(elem) 在尾部加入一个数据。

c.resize(num)     重新设置该容器的大小

c.size()         回容器中实际数据的个数。

c.begin()           返回指向容器第一个元素的迭代器

c.end()             返回指向容器最后一个元素的迭代器

#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
int main() {int n;cin >> n;vector<int> v;for (int i = 0; i < n; i++) {int a;cin >> a;if(a!=0)v.push_back(a);else {v.pop_back();}}int ans = 0;for (int i = 0; i < v.size(); i++) {ans = ans + v[i];}cout << ans << endl;
}

第五天

2.古堡之门:数字之和挑战 - 蓝桥云课 (lanqiao.cn)

思路:

这题要考虑最大值和最小值的限制,还有未longlong也会出错。 

#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
int main() {long long n, m, k;cin >> n >> m >> k;long long ans = 0,mint=0;for (long long i = n; i >= 1; i--) {if (m == 0) {break;}mint = n - i + 1 + mint;ans = ans + i;m--;}if (k <= ans&&mint<=k) {cout << "Yes";}else {cout << "No";}return 0;
}

第六天

P1060 [NOIP2006 普及组] 开心的金明 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)

思路:

这是一个经典的01背包,我用而被的dp数组好像卡了一个数据点,换成优化后的一维dp数组才可以通过。

#include<iostream>
#include<algorithm>
using namespace std; 
int w[30005];
struct node {int a;int b;
}k[30005];
int main() {int p, n;cin >> p >> n;for (int i = 1; i <= n; i++) {cin >> k[i].a >> k[i].b;}for (int i = 1; i <= n; i++) {for (int j = p; j >=k[i].a; j--) {w[j] = max(w[j], w[j - k[i].a]+ k[i].a * k[i].b);}}cout << w[p];
}

相关文章:

第四周刷题小结

第一天 P1068 [NOIP2009 普及组] 分数线划定 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 思路&#xff1a; 这个题感觉不难&#xff0c;主要是用到了结构体cmp的自定义排序&#xff0c;但是还是错了一次&#xff0c;就是没注意到题目给的条件。 #include<iostream&g…...

基于Java中的SSM框架实现考研指导平台系统项目【项目源码+论文说明】

基于Java中的SSM框架实现考研指导平台系统演示 摘要 应对考研的学生&#xff0c;为了更好的使校园考研有一个更好的环境好好的学习&#xff0c;建议一个好的校园网站&#xff0c;是非常有必要的。提供学生的学习提供一个交流的空间。帮助同学们在学习高数、学习设计、学习统计…...

项目2-用户登录

1.创建项目 2.引入前端代码并检查是否有误 3.定义接口 需求分析 对于后端开发⼈员⽽⾔, 不涉及前端⻚⾯的展⽰, 只需要提供两个功能 1. 登录⻚⾯: 通过账号和密码, 校验输⼊的账号密码是否正确, 并告知前端 2. ⾸⻚: 告知前端当前登录⽤⼾. 如果当前已有⽤⼾登录, 返回登录的账…...

网易web安全工程师进阶版课程

课程介绍 《Web安全工程师&#xff08;进阶&#xff09;》是由“ i春秋学院联合网易安全部”出品&#xff0c;资深讲师团队通过精炼的教学内容、丰富的实际场景及综合项目实战&#xff0c;帮助学员纵向提升技能&#xff0c;横向拓宽视野&#xff0c;牢靠掌握Web安全工程师核心…...

【Postman】工具使用介绍

一、postman工具介绍 1.什么是postman postman是谷歌开发的一款网页调试和接口测试工具&#xff0c;能够发送任何请求类型的http请求&#xff0c;支持GET/POST/PUT/DELETE等方法。postman简单易用&#xff0c;可以直接填写URL&#xff0c;header&#xff0c;body就可以发送一…...

【vue核心技术实战精讲】1.3 - 1.6 VUE 指令 (上)

前言 上节,我们学习了 Vue的起步 和 插值表达式 本节内容 Vue指令之v-text 和 v-htmlVue指令之v-if 和 v-showVue指令之v-bind绑定Vue指令之v-on事件处理 1、v-text 和 v-html {{}} 和v-text的作用是一样的 都是插入值,直接渲染 ≈ innerTextv-html既能插入值 又能插入标签…...

vscode使用Runner插件将.exe文件统一放到一个目录下

找到右下角管理&#xff0c;点击扩展。 找到Code Runner插件&#xff0c;打开扩展设置。 向下翻&#xff0c;找到Executor Map&#xff0c;点击在settings.json中编辑。 在c和c的配置命令栏中增加\\\output\\即可。&#xff08;增加的目录不能自动创建&#xff0c;需要手动创建…...

[commonjs--resolver] Missing “./jsx-runtime.js“ specifier in “react“ package

修复vite构建时错误 vite打包,第三方包引用的react版本不一致问题修复(不是最优解) // vite.config.js import { defineConfig } from vite; import react from vitejs/plugin-react; import path from path;export default defineConfig({plugins: [react(), // 如果使用Rea…...

ETH Gas 之 Base Fee Priority Fee

前情回顾 ETH网络 之 Gas EIP-1559 EIP-1559 EIP-1559是以太坊改进提案&#xff08;Ethereum Improvement Proposal&#xff09;&#xff0c;旨在改进以太坊的交易费用机制。该提案引入了一种新的交易费用模型&#xff0c;以提高交易费用的可预测性和网络的效率。我们本文各…...

【小白入门篇1】GPT到底是怎样练成?

由于具有代表性的OpenAI公司GPT模型并没有开源&#xff0c;所以本章节是参考一些开源和现有课程&#xff08;李宏毅&#xff09;讲解ChatGPT原理。本章没有涉及到很多数学运算&#xff0c;比较适合小白了解GPT到底是怎么练成。GPT的三个英文字母分别代表Generative(生成式)&…...

Django——forms组件

Django——forms组件 forms组件&#xff1a;通过后端在Django中定义forms类&#xff0c;可以在 html 中动态的生成一个表单&#xff1b;检验用户提交的数据。 在应用中创建一个名为 &#xff1a;forms 的py文件 # 导入 forms 组件 from django import forms# 自定义 forms …...

利用K8S Statefulset搭建Etcd集群 - PVC存储

概述 在测试过程中发现&#xff0c;直接使用本地存储&#xff0c;当节点机器损坏了&#xff0c;对应机器的etcd数据也丢失了&#xff0c;故而做了利用K8S PV&#xff0c;PVC以及NFS来存储数据的尝试&#xff0c;经过一番折腾&#xff0c;测试成功&#xff0c;博文记录&#xf…...

手撕算法-接雨水

描述 分析 i位置能积累的雨水量&#xff0c;等于其左右两边最大高度的最小值。为了能获取i位置左右两边的最大高度。使用动态规划。两个dp数组&#xff1a; leftMaxrightMax 其中 leftMax[i] 代表i位置左边的最大高度rightMax[i] 代表i位置右边的最大高度 初始状态&#x…...

探索AI大模型学习:理论基础、技术突破与未来挑战

在当今技术飞速发展的时代&#xff0c;人工智能&#xff08;AI&#xff09;大模型学习无疑是推动科技进步和创新的关键力量。AI大模型学习的核心在于通过训练大规模的数据集来提升模型的性能&#xff0c;使之能够更准确、更高效地完成各种任务&#xff0c;从而在多个领域中实现…...

Linux:点命令source

相关阅读 Linuxhttps://blog.csdn.net/weixin_45791458/category_12234591.html?spm1001.2014.3001.5482 source命令用于读取一个文件的内容并在当前Shell环境&#xff08;包括交互式Shell或是非交互式Shell&#xff09;执行里面的命令。它被称为点命令是因为命令名source也可…...

iOS开发 - 转源码 - __weak问题解决

iOS开发 - 转源码 - __weak问题解决 在使用clang转换OC为C代码时&#xff0c;可能会遇到以下问题 cannot create __weak reference in file using manual reference 原因 __weak弱引用是需要runtime支持的&#xff0c;如果我们还只是使用静态编译&#xff0c;是无法正常转换的…...

【Linux基础】dash和bash简介

Dash&#xff08;Debian Almquist Shell&#xff09;和 Bash&#xff08;Bourne Again Shell&#xff09;是 Unix/Linux 系统中的命令行 shell&#xff0c;用于执行命令、管理文件系统、编写脚本等任务的工具。 一、Dash和Bash的区别&#xff1a; Bash&#xff08;Bourne Agai…...

精读《如何做好 CodeReview》

1 引言 任何软件都是协同开发的&#xff0c;所以 CodeReview 非常重要&#xff0c;它可以帮助你减少代码质量问题&#xff0c;提高开发效率&#xff0c;提升稳定性&#xff0c;同时还能保证软件架构的稳定性&#xff0c;防止代码结构被恶意破坏导致难以维护。 所以 CodeRevie…...

双指针(滑动窗口)-算法刷题

一.移动零&#xff08;. - 力扣&#xff08;LeetCode&#xff09;&#xff09; 算法思想 &#xff1a; 设置两个指针left,right&#xff0c;将数组分为三块[0,left]为不为0的元素&#xff0c;[left1,right-1]为0元素&#xff0c;[right,num.size()-1]为未扫描的区域&#xff0c…...

上位机图像处理和嵌入式模块部署(qmacvisual之ROI设定)

【 声明&#xff1a;版权所有&#xff0c;欢迎转载&#xff0c;请勿用于商业用途。 联系信箱&#xff1a;feixiaoxing 163.com】 ROI&#xff0c;全称是region of interest&#xff0c;也就是感兴趣区域。这里面一般分成两种情况&#xff0c;一种是所有的算法都依赖于这个ROI&a…...

从read()到硬盘:用strace和bpftrace动态追踪Linux内核文件读取的完整路径(附实战脚本)

从read()到硬盘&#xff1a;用strace和bpftrace动态追踪Linux内核文件读取的完整路径&#xff08;附实战脚本&#xff09; 当线上服务出现文件读取延迟时&#xff0c;大多数系统工程师的第一反应是检查磁盘I/O指标。但真正的挑战在于&#xff1a;如何准确定位从用户态系统调用到…...

YOLO26功能体验:官方镜像预置多种权重,开箱即用体验最新模型

YOLO26功能体验&#xff1a;官方镜像预置多种权重&#xff0c;开箱即用体验最新模型 1. 引言&#xff1a;告别环境配置&#xff0c;直接上手YOLO26 如果你对计算机视觉感兴趣&#xff0c;想试试最新的目标检测模型&#xff0c;那么YOLO26绝对值得关注。作为YOLO系列的最新成员…...

CLIP-GmP-ViT-L-14入门指南:理解ImageNet/ObjectNet双基准评估意义

CLIP-GmP-ViT-L-14入门指南&#xff1a;理解ImageNet/ObjectNet双基准评估意义 1. 什么是CLIP-GmP-ViT-L-14 CLIP-GmP-ViT-L-14是一个经过几何参数化&#xff08;GmP&#xff09;微调的CLIP模型&#xff0c;在计算机视觉领域具有出色的表现。这个模型最大的特点是它在ImageNe…...

网站创建时间对网站 SEO 优化有什么影响

网站创建时间对网站 SEO 优化有什么影响 在当今竞争激烈的互联网市场中&#xff0c;网站的 SEO&#xff08;搜索引擎优化&#xff09;优化是吸引流量、提高曝光率的关键因素之一。而在众多影响 SEO 的因素中&#xff0c;网站创建时间作为一个被忽视的因素&#xff0c;其实也有…...

ddsad

sdsfdjsufhfsuh...

学术研究利器:OpenClaw+gemma-3-12b-it自动整理文献综述

学术研究利器&#xff1a;OpenClawgemma-3-12b-it自动整理文献综述 1. 为什么需要自动化文献整理工具 作为一名经常需要阅读大量文献的研究者&#xff0c;我深刻体会到手动整理文献的痛点。每次写论文前&#xff0c;我需要花费数小时甚至数天时间从几十篇PDF中提取关键信息&a…...

基于大数据与深度学习的二手房价格预测系统设计与实现-完整源码论文毕设项目

博主介绍&#xff1a;&#x1f449;全网个人号和企业号粉丝40W,每年辅导几千名大学生较好的完成毕业设计&#xff0c;专注计算机软件领域的项目研发&#xff0c;不断的进行新技术的项目实战&#x1f448; ⭐️热门专栏推荐订阅⭐️ 订阅收藏起来&#xff0c;防止下次找不到 &am…...

别再只用TF-IDF了!揭秘TextRank与BERT结合的关键词提取新玩法(附Colab实操)

超越TF-IDF&#xff1a;TextRank与BERT融合的关键词提取实战指南 在信息爆炸的时代&#xff0c;快速准确地从海量文本中提取核心关键词已成为NLP工程师的必备技能。传统方法如TF-IDF虽然简单高效&#xff0c;但面对社交媒体短文本、学术论文摘要等复杂场景时&#xff0c;往往力…...

Uppy与MongoDB Atlas集成指南:云数据库中的文件元数据存储解决方案

Uppy与MongoDB Atlas集成指南&#xff1a;云数据库中的文件元数据存储解决方案 【免费下载链接】uppy The next open source file uploader for web browsers :dog: 项目地址: https://gitcode.com/gh_mirrors/up/uppy Uppy作为现代Web应用的文件上传解决方案&#xff…...

ADXL345嵌入式驱动开发:I²C/SPI寄存器配置与FreeRTOS中断集成

1. ADXL345加速度传感器库深度解析&#xff1a;面向嵌入式工程师的底层驱动开发指南ADXL345是Analog Devices公司推出的超低功耗、高分辨率&#xff08;13位&#xff09;、数字输出三轴加速度传感器&#xff0c;广泛应用于姿态检测、振动监测、跌倒报警、工业预测性维护及可穿戴…...