Peter算法小课堂—自定义容器

太戈编程第308题

暴力法

cin>>n>>m;
for(int i=0;i<n;i++) cin>>name[i]>>year[i];
for(int i=0;i<m;i++){int x;string y;cin>>x>>y;int OK=0;for(int j=0;j<n;j++){if(name[j]==y&&year[j]==x){OK=1;break;}}cout<<OK<<" ";
}

这个算法复杂度为O(nm),显然有更快的算法

自定义类型

 但是,这样写有个很危险的错误,如下

#include <bits/stdc++.h>
using namespace std;
struct dog{string name;int year;
};
int main(){set<dog> s;dog a,b;a.name="mike";a.year=2020;b.name="wangcai";b.year=2019;s.insert(a);s.insert(b);return 0;
}

运行出来是这样的,

 原因很简单,因为set的功能是排序、去重,然而结构体排序要加上“.",所以会报错

改后代码,

#include <bits/stdc++.h>
using namespace std;
struct dog{string name;int year;bool operator<(const dog&d)const {if(year<d.year) return 1;if(year>d.year) return 0;if(name<d.name) return 1;return 0;}
};
int main(){set<dog> s;dog a,b;a.name="mike";a.year=2020;b.name="wangcai";b.year=2019;s.insert(a);s.insert(b);return 0;
}

那么,回到原题,代码该怎么写呢?

#include <bits/stdc++.h>
using namespace std;
struct dog{string name;int year;bool operator<(const dog&d)const {if(year<d.year) return 1;if(year>d.year) return 0;if(name<d.name) return 1;return 0;}
};
int main(){set<dog> s;dog d;int n,m;cin>>n>>m;for(int i=0;i<n;i++){cin>>d.name>>d.year;s.insert(d);}for(int i=0;i<m;i++){cin>>d.year>>d.name;if(s.count(d)) cout<<"1";else cout<<"0";}return 0;
}

太戈编程第1497题

无set

#include <bits/stdc++.h>
using namespace std;
const int N=100009;
struct student{int id,score;bool operator<(const student&b)const {if(score>b.score) return 1;if(score<b.score) return 0;if(id<b.id) return 1;return 0;}
};
student f[N];
int main(){int n;cin>>n;for(int i=1;i<=n;i++){cin>>f[i].score;f[i].id=i;}sort(f+1,f+1+n);for(int i=1;i<=n;i++){cout<<f[i].id<<" "<<f[i].score<<endl;}return 0;
}

有set

#include <bits/stdc++.h>
using namespace std;
const int N=100009;
struct student{int id,score;bool operator<(const student&b)const {if(score>b.score) return 1;if(score<b.score) return 0;if(id<b.id) return 1;return 0;}
};
int main(){int n;cin>>n;set<student> s;student x;for(int i=0;i<n;i++){cin>>x.score;x.id=i+1;s.insert(x);}set<student>::iterator it;for(it=s.begin();it!=s.end();it++)cout<<(*it).id<<" "<<(*it).score<<endl;return 0;
}

当然这个代码也有高级版,但要升级到c++14,如下

//不推荐使用,OJ好像不行
#include <bits/stdc++.h>
using namespace std;
const int N=100009;
struct student{int id,score;bool operator<(const student&b)const {if(score>b.score) return 1;if(score<b.score) return 0;if(id<b.id) return 1;return 0;}
};
int main(){int n;cin>>n;set<student> s;int x;for(int i=0;i<n;i++){cin>>x;s.insert({i+1,x});}set<student>::iterator it;for(it=s.begin();it!=s.end();it++)cout<<(*it).id<<" "<<(*it).score<<endl;return 0;
}

太戈编程第309题

大家认真敲代码15min,15min后开讲

 

#include <bits/stdc++.h>
using namespace std;
struct ren{int x,id;bool operator<(const ren&b)const{if(x<b.x) return 1;if(x>b.x) return 0;if(id<b.id) return 1;return 0;}
};
int main(){int n;cin>>n;set<ren> s;set<ren>::iterator it;ren d;for(int i=1;i<=n;i++){cin>>d.x;d.id=i;s.insert(d); }set<int> ok;for(int i=1;i<=n;i++){it=s.begin();d.x=(*it).x+3;d.id=(*it).id;s.erase(it);s.insert(d);ok.insert(d.id);}cout<<n-ok.size()<<endl;return 0;
}

希望这些对大家有用,三联必回

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/192028.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Vmware虚拟机重装 虚拟机能ping通主机,而主机不能ping通虚拟机的问题

CClean&#xff0c;用它把你电脑上已经卸载的软件但是注册表还没删干净的把注册表删干净&#xff0c;之前说的那种情况&#xff08;虚拟网络编辑器打不上勾&#xff09;就迎刃而解了。 Ps&#xff1a;CClean&#xff1a;再网上百度就可以查到&#xff0c;软件对用户也很友好&a…

环境变量小节

这是写的第二篇环境变量博客&#xff0c;写了一年多了&#xff0c;第一次出现把自己博客删了的情况&#xff0c;不知道为什么明明发表了&#xff0c;然后就把草稿箱和回收站的删了&#xff0c;结果晚上发现没发表&#xff0c;回收站删除是无法找回的&#xff0c;以后还是要慎重…

macOS Big Sur(macos11版本)

macOS Big Sur是苹果推出的最新操作系统&#xff0c;具有以下特点&#xff1a; 全新的设计风格&#xff1a;Big Sur采用了全新的设计语言&#xff0c;包括更加圆润的窗口和控件、更加鲜明的色彩和更加简洁的界面。这种设计风格使得操作系统更加美观和易用。强大的性能表现&…

“糖尿病日”感言

长期旺盛的写作欲&#xff0c;今天忽地就莫名其妙地衰退下来了。感到浑身都不舒服&#xff0c;特别是过去从未出现过的腰微痛、乏力现象发生了。 转念一想&#xff0c;或是老龄人一日不如一日的正常反应吧&#xff1f;而且&#xff0c;今天恰逢“ 联合国糖尿病日”&#xff0c…

Python之文件与文件夹操作及 pytest 测试习题

目录 1、文本文件读写基础。编写程序&#xff0c;在 当前目录下创建一个文本文件 test.txt&#xff0c;并向其中写入字符串 hello world。2、编写一个程序 demo.py&#xff0c;要求运行该程序后&#xff0c;生成 demo_new.py 文件&#xff0c;其中内容与demo.py 一样&#xff0…

NO.304 二维区域和检索 - 矩阵不可变

题目 给定一个二维矩阵 matrix&#xff0c;以下类型的多个请求&#xff1a; 计算其子矩形范围内元素的总和&#xff0c;该子矩阵的 左上角 为 (row1, col1) &#xff0c;右下角 为 (row2, col2) 。 实现 NumMatrix 类&#xff1a; NumMatrix(int[][] matrix) 给定整数矩阵 …

【Qt之QWizard】使用1

QWizard使用 描述方法枚举&#xff1a;enum QWizard::WizardButton枚举&#xff1a;enum QWizard::WizardOption枚举&#xff1a;enum QWizard::WizardStyle枚举&#xff1a;enum QWizard::WizardPixmap常用成员方法槽函数信号 示例设置标题添加page页设置按钮文本设置自定义按…

房产中介租房小程序系统开发搭建:详细指南教你如何构建

随着微信小程序的日益普及&#xff0c;越来越多的企业和个人开始尝试开发自己的小程序。以下是制作一个房地产微信小程序的详细教程&#xff0c;希望对大家有所帮助。 一、注册登录乔拓云平台&#xff0c;进入后台 首先&#xff0c;需要注册并登录乔拓云平台&#xff0c;该平台…

爬虫,TLS指纹 剖析和绕过

当你欲爬取某网页的信息数据时&#xff0c;发现通过浏览器可正常访问&#xff0c;而通过代码请求失败&#xff0c;换了随机ua头IP等等都没什么用时&#xff0c;有可能识别了你的TLS指纹做了验证。 解决办法&#xff1a; 1、修改 源代码 2、使用第三方库 curl-cffi from curl…

警方打击了大规模网络钓鱼提供商BulletProftLink

导语 最近&#xff0c;马来西亚皇家警察宣布成功打击了一个名为BulletProftLink的大规模网络钓鱼提供商。这个提供超过300个钓鱼模板的平台被查封&#xff0c;给全球网络安全带来了巨大的利好消息。本文将带您了解这个引人注目的行动背后的故事&#xff0c;并揭示BulletProftLi…

密钥安全存储方案探讨与实践

随着信息技术的迅猛发展和应用范围的不断扩大&#xff0c;我们日常生活中的许多方面已经与信息技术密不可分。而在信息安全领域中&#xff0c;密钥的安全存储显得尤为重要。本文将探讨密钥安全存储的必要性、相关技术和实践方案&#xff0c;并提出一些解决方案。 一、密钥安全存…

Nexus的Maven私有仓库搭建

Nexus的maven私有仓库搭建 一、了解 maven仓库设置 默认设置 其中&#xff1a; maven-central: 预定义的代理Maven Central仓库&#xff0c;它包含了大量的开源Java依赖包。maven-public: 存储库是一个组合存储库&#xff0c;它包含了maven-releases和maven-snapshots存储库…

绘制函数图像

import pandas as pd from plotnine import *# 定义自定义函数 def f(x):return x**2# 生成 x 值 x_values range(-10, 11)# 生成对应的 y 值 y_values [f(x) for x in x_values]# 创建数据框 df pd.DataFrame({x: x_values, y: y_values}) # df为&#xff1a;x y 0 -10…

Python入门教程:12个常用基础语法详解

文章目录 前言1.多个字符串组合为一个字符串2. 字符串拆分为子字符串列表3. 统计列表中元素的次数4.使用try-except-else-block模块5. 使用枚举函数得到key/value对6. 检查对象的内存使用情况7. 合并字典8. 计算执行一段代码所花费的时间9. 列表展开10. 列表采样11. 数字化12. …

redis 安装

概览 1.redis下载 1.1.下载Redis 历史版本redis网址&#xff1a;http://download.redis.io/releases/ 建议下载和我一样的版本 6.0.5 将刚才下载好的压缩文件移动到local文件夹内,可以手动移动或者用命令移动 命令行 移动命名&#xff1a;mv 将下载的包拖动到命令行 /usr/loc…

WebGl-Blender:建模 / 想象成形 / 初识 Blender

一、理解Blender 欢迎来到Blender&#xff01;Blender是一款免费开源的3D创作套件。 使用Blender&#xff0c;您可以创建3D可视化效果&#xff0c;例如建模、静态图像&#xff0c;3D动画&#xff0c;VFX&#xff08;视觉特效&#xff09;快照和视频编辑。它非常适合那些受益于…

王道数据结构课后代码题p19 第14题请设计一个尽可能高效的算法,计算并输出所有可能的三元组(a,b,c) 中的最小距离。(c语言代码实现)

本题其实就是找a到c的最小值 有讲解p19 第14题 c语言实现王道数据结构课后代码题_哔哩哔哩_bilibili 下方有图&#xff1a; 本题代码如下 int abs(int a)//计算绝对值 {if (a < 0)return -a;elsereturn a; } int min(int a, int b, int c)//a是否为三个数中的最小值 {if …

使用ant+jmeter如何生成html报告

一、安装ant 下载apache-ant&#xff0c;放到对应路径下&#xff0c;然后进行环境变量配置。系统变量的CLASSPATH添加E:\Installation Pack\eclipse\apache-ant-1.9.6\lib;用户变量的PATH添加&#xff1a;E:\Installation Pack\eclipse\apache-ant-1.9.6\bin。打开cmd&#xf…

【业务场景】长列表的处理

长列表的处理 1. 什么是长列表 在前端开发中&#xff0c;经常会遇到列表展示&#xff0c;如果列表项的数量比较多&#xff0c;我们一般选择采用分页的方式来进行处理 但传统的前后翻页方式只适用于后台的管理系统中&#xff0c;而在用户端、尤其是在移动端&#xff0c;为了保…

基于51单片机PCF8591数字电压表数码管显示设计( proteus仿真+程序+设计报告+讲解视频)

PCF8591数字电压表数码管显示 1.主要功能&#xff1a;讲解视频&#xff1a;2.仿真3. 程序代码4. 设计报告5. 设计资料内容清单&&下载链接资料下载链接&#xff08;可点击&#xff09;&#xff1a; 基于51单片机PCF8591数字电压表数码管设计( proteus仿真程序设计报告讲…