6.4学习总结

news2024/11/24 19:10:48

Codeforces Round 950 (Div. 3)A、B题解

解题思路

开一个数组来记录A,B,C,D,E,F,G难度题目出现的次数,因为每一轮比赛都需要每一种难度都有一题,所以我们只要根据要出的比赛的轮数对每一个难度的题目进行自减,最后遍历数组把所有为负数的题目的数量记录下来就是需要出的题目的数量了。

代码
#include <iostream>
#include <cstdio>
#include <fstream>
#include <algorithm>
#include <cmath>
#include <deque>
#include <vector>
#include <queue>
#include <string>
#include <cstring>
#include <map>
#include <stack>
#include <set>
using namespace std;
int main()
{
    int t,n,m;
    char a[100];
    int b[10];
    scanf("%d",&t);
    for(int i=0;i<t;i++)
    {
        int sum=0;
        scanf("%d%d",&n,&m);
        for(int x=0;x<7;x++)
        {
            b[x]=0;
        }
        for(int x=0;x<n;x++)
        {
            cin>>a[x];
            b[a[x]-'A']++;
        }
        for(int x=0;x<7;x++)
        {
            b[x]-=m;
            if(b[x]<0)
            {
                sum-=b[x];
            }
        }
        printf("%d\n",sum);
    }
    return 0;
}

解题思路

用一个数组来保存正方体的顺序,记录魔方的值,然后对数组进行排序。应为如果两个立方体的数值相同,它们可以按照任意顺序排列所以我们不需要找到魔方的位置,只需要找到与魔方有着相同的值的立方体(应为魔方可能出现在任何与魔方有着相同的值的立方体的位置),然后对所有的与魔方有着相同的值的立方体的位置进行判断看是否有可能被丢掉(一定、有可能、不可能)。

代码
#include <iostream>
#include <cstdio>
#include <fstream>
#include <algorithm>
#include <cmath>
#include <deque>
#include <vector>
#include <queue>
#include <string>
#include <cstring>
#include <map>
#include <stack>
#include <set>
using namespace std;
int cmp(int x,int y)
{
    return x>y;
}
int main()
{
    int t,n,f,k;
    scanf("%d",&t);
    for(int i=0;i<t;i++)
    {
        int a[105]={0};
        scanf("%d%d%d",&n,&f,&k);
        for(int x=0;x<n;x++)
        {
            scanf("%d",&a[x]);
        }
        f=a[f-1];
        sort(a,a+n,cmp);
        int g=0;
        while(g<=n&&a[g]!=f)
        {
            g++;
        }
        int y=g;
        int flat=0,flat1=0;
        while(a[y]==f&&y>=0)
        {
            if(y<k)
            {
                flat=1;
                break;
            }
            y--;
        }
        if(!flat)
        {
            printf("NO\n");
            continue;
        }
        y=g;
        while(a[y]==f&&y<n)
        {
            if(y>=k)
            {
                flat1=1;
                break;
            }
            y++;
        }
        if(flat1)
        {
            printf("MAYBE\n");
        }
        else
        {
            printf("YES\n");
        }
    }
    return 0;
}

Mysql学习总结

联结(补)

表别名

别名不只是可以给列和计算字段使用,还可以给表使用,这样用有两个好处:

  • 缩短SQL语句
  • 允许在单条SELECT语句中多次使用相同的表。

SELECT cust_name, cust_contact

FROM customers AS c, orders AS o, orderitems AS oi

WHERE c.cust_id = o.cust_id

AND oi.order_num = o.order_num

AND prod_id = 'TNT2';

自联结

例:如果某物品(ID为DTNTR)存在问题,因此想知道生产该物品的供应商生产的其他物品是否也存在这些问题。此查询要求首先找到ID为DTNTR的物品的供应商,然后找出这个供应商生产的其他物品。

SELECT p1.prod_id, p1.prod_name

FROM products AS p1, products AS p2

WHERE p1.vend_id = p2.vend_id AND p2.prod_id ='DTNTR';

组合查询

执行多个查询并将结果作为单个查询结果返回。

使用情况:

  • 在单个查询中从不同的表返回类似结构的数据
  • 对单个表执行多个查询,按单个查询返回数据
UNION关键字

只需要把给出的每一条select语句之间用union关键字连接就行了。

#单条语句

SELECT vend_id, prod_id, prod_price

FROM products

WHERE prod_price <= 5;

SELECT vend_id, prod_id, prod_price

FROM products

WHERE vend_id IN (1001,1002);

#组合上述语句

SELECT vend_id, prod_id, prod_price

FROM products

WHERE prod_price <= 5

UNION

SELECT vend_id, prod_id, prod_price

FROM products

WHERE vend_id IN (1001, 1002);

#等于

SELECT vend_id, prod_id, prod_price

FROM products

WHERE prod_price <= 5

OR vend_id IN (1001, 1002);

union使用须知

  • union必须由两条或两条以上的select语句组成,语句之间用关键字union分隔。
  • 所有的查询必须有着相同的语句结构(列数相同)
  • 所有的查询的列的数据类型要相同(实际上只要列的数据类型兼容就行了例如整形和浮点型时相互兼容的)。
  • union会自动的从查找到的结果集中去除相同的行,如果要显示搜索到的所有行需要使用 union all关键字。
  • 如果使用order by关键字进行排序,那么只能使用一次,要放在最后的一条select语句中。

全文本搜索

全文本搜索是指在数据库中查找包含特定关键词或短语的文本的过程。它与传统的基于精确匹配的搜索不同,全文本搜索允许进行模糊匹配部分匹配,以便找到与搜索条件相关的文本。

并非所有的引擎都是支持全文本搜索的,所以如要使用全文本搜索最好在使用之前了解一下使用的引擎是否支持全文本搜索。Mysql常用的两个引擎innodb和Myisam都是支持全文本搜索的,如果要对中文进行搜索还需要进一步的了解。

like关键字和正则表达式的限制

  • 搜索花费的时间多。(因为搜索时会遍历整个数据表对每一个数据进行对比)
  • 无法明确的控制匹配的条件。(当对搜索数据的要求多起来,就会很难被实现。例:指定一个词不允许匹配,另一个词必须匹配,而第二个词必须在第一个词的匹配条件成立之后才生效)。
  • 没有提供一种智能化的选择结果的方法。(例如,一个特殊词的搜索将会返回包含该词的所有行,而不区分包含单个匹配的行和包含多个匹配的行(按照可能是更好的匹配来排列它们)。类似,一个特殊词的搜索将不会找出不包含该词但包含其他相关词的行。)

而以上这些缺陷甚至更多都可以通过全文本来避免。

使用全文本搜索的准备

为了进行全文本搜索,必须索引被搜索的列,而且要随着数据的改变不断地重新索引。在对表列进行适当设计后,MySQL会自动进行所有的索引和重新索引。
在索引之后,SELECT可与Match()和Against()一起使用以实际执行搜索。

启用全文本搜索

一般在创建表的时候就启用。

CREATE TABLE语句接收FULLTEXT子句,它需要被索引列的使用逗号分隔的列表(当fulltext语句中有多个列时使用逗号隔开)。

CREATE TABLE productnotes //创建一个表

(

note_id int NOT NULL AUTO_INCREMENT, //创建一个int型的列,不能为空,会自动递增

pord_id char(10) NOT NULL,

note_date datetime NOT NULL.

note_text text NULL,

PRIMARY KEY(note_id), //设置主键

FULLTEXT(note_text) //启用note_text列的全文本搜索功能

)ENGINE=MyISAM; //指定储存引擎为MyISAM

如果正在导入数据到一个新表,此时不应该启用 FULLTEXT 索引。应该首先导入所有数据,然后再修改表,定义 FULLTEXT 。这样有助于更快地导入数据(使索引数据的总时间小于在导入每行时分别进行索引所需的总时间。

进行全文本搜索

match():指定要搜索的列。(match()中的参数必须和fulltext()中的参数保持一致)

against():指定要搜索的表达式。

如想区分大小写使用binary关键字。

例:

SELECT note_text,

Match(note_text) Against('rabbit') AS rank

FROM productnotes;

SELECT note_text AS rank

FROM productnotes

WHERE note_text like 'rabbit';

这两段代码的区别就是:使用全文本搜索的根据搜索词出现的次数自动的进行排序,而like关键字则不会。

扩展搜索

全文本搜索还提供了扩展搜索的功能,也就是说它不仅仅局限于你给出的来进行搜索,还会根据你给出的词对相关的词进行扩展搜索,比如你要搜索apple,他会帮你扩展搜索tree、fruit等。

需要使用时需要在against()中加上with query expansion就行了

例:

SELECT note_text,

Match(note_text) Against('rabbit'WITH QUERY EXPANSION) AS rank

FROM productnotes;

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【NI国产替代】电池模拟器,快速模拟 3C 产品电池的充放电功能

电池模拟器 快速模拟 3C 产品电池的充放电功能输出灵活可调节的电压/电流内置双向 DC-DC 降压变换器为 3C 产品提供漏电检测 电池模拟器系列包含单节双通道&#xff08;1S&#xff09;、双节双通道&#xff08;2S&#xff09;、三节单通道&#xff08;3S&#xff09;三种规格&…

三十六篇:未来架构师之道:掌握现代信息系统典型架构

未来架构师之道&#xff1a;掌握现代信息系统典型架构 1. 引言 在企业的数字化转型浪潮中&#xff0c;信息系统架构的角色变得日益重要。它不仅承载了企业的IT战略&#xff0c;更是确保企业在复杂、动态的市场环境中稳定运行的关键。作为信息系统的骨架&#xff0c;一个精心设…

张量之力:人工智能的多维舞台

在人工智能&#xff08;AI&#xff09;的广阔天地里&#xff0c;张量&#xff08;Tensor&#xff09;这一数学概念如同璀璨的明星&#xff0c;以其独特的魅力和强大的功能&#xff0c;为AI技术的发展和应用注入了新的活力。张量&#xff0c;这个源自物理学的概念&#xff0c;如…

【云原生Kubernetes项目部署】k8s集群+高可用负载均衡层+防火墙

目录 环境准备 拓朴图 项目需求 一、Kubernetes 区域可采用 Kubeadm 方式进行安装 1.1所有节点master、node01、node02 1.2所有节点安装docker 1.3所有节点安装kubeadm&#xff0c;kubelet和kubectl 1.4部署K8S集群 1.4.1复制镜像和脚本到 node 节点&#xff0c;并在 …

数据总线、位扩展、字长

数据总线&#xff08;Data Bus&#xff09; 定义 数据总线是计算机系统中的一组并行信号线&#xff0c;用于在计算机内部传输数据。这些数据可以在中央处理器&#xff08;CPU&#xff09;、内存和输入/输出设备之间传输。 作用 数据传输&#xff1a;数据总线负责在计算机各…

中间代码生成

一&#xff0e;实验题目 DO-WHILE循环语句的中间代码生成 二&#xff0e;实验目的 通过设计、编制、调试一个 do-while 循环语句的语法及语义分析程序&#xff0c;加深对 法及语义分析原理的理解&#xff0c;并实现词法分析程序对单词序列的词法检查和分析。 三&#xff0e; 实…

SploitScan:一款多功能实用型安全漏洞管理平台

关于SploitScan SploitScan是一款功能完善的实用型网络安全漏洞管理工具&#xff0c;该工具提供了用户友好的界面&#xff0c;旨在简化广大研究人员识别已知安全漏洞的相关信息和复现过程。 SploitScan可以帮助网络安全专业人员快速识别和测试已知安全漏洞&#xff0c;如果你需…

读书笔记-《软件定义安全》之二:SDN/NFV环境中的安全问题

第2章 SDN/NFV环境中的安全问题 1.架构安全 SDN强调了控制平面的集中化&#xff0c;从架构上颠覆了原有的网络管理&#xff0c;所以SDN的架构安全就是首先要解决的问题。例如&#xff0c;SDN实现中网络控制器相关的安全问题。 1.1 SDN架构的安全综述 从网络安全的角度&…

基于Win11下的Wireshark的安装和使用

Wireshark的安装和使用 前言一、Wireshark是什么简介 二、下载Wireshark下载过程查看自己电脑配置 三、安装Wireshark安装过程安装组件创建快捷方式winPacpNpcap 打开检验 四、使用Wireshark实施抓包捕获数据包 五、基于Wireshark使用显示过滤器简介使用方法注意ICMP的请求和应…

vue3+ts+vite项目开发--知识点梳理01

vue3tsvite项目开发--知识点梳理01 创建vue3项目01 tsconfig.node.json文件中extends报错02 知识点&#xff1a;用nvm安装最新版本的node03. template标签中的#表示啥意思04 ts中 &#xff1f;&#xff1f;使用05 ts中 reduce06 vue3ts中watch和watchEffect监听使用07 unocss用…

大屏可视化建设方案(word)

1.系统概述 1.1.需求分析 1.2.重难点分析 1.3.重难点解决措施 2.系统架构设计 2.1.系统架构图 2.2.关键技术 2.3.接口及要求 3.系统功能设计 3.1.功能清单列表 3.2.数据源管理 3.3.数据集管理 3.4.视图管理 3.5.仪表盘管理 3.6.移动端设计 3.1.系统权限设计 3.…

RTOS笔记--信号量+互斥量+事件组

信号量的本质 信号量是一个特殊的队列&#xff0c;但并不涉及数据传输&#xff0c;因此不需要读写位置和发送者列表&#xff0c;但是多了一个最大计数值。 个人理解&#xff1a;信号量类似一个加入了保护机制的全局变量&#xff0c;不会因为中断切换的原因而导致数据出错。 信号…

计算机缺失msvcp100.dll如何解决?教你5种简单高效的修复方法

在现代科技发展的时代&#xff0c;计算机已经成为我们生活和工作中不可或缺的工具。然而&#xff0c;在使用计算机的过程中&#xff0c;我们常常会遇到各种问题和困扰。其中之一就是计算机找不到msvcp100.dll文件。这个问题可能会给我们的生活和工作带来很多不便&#xff0c;下…

Unity2D游戏制作入门 | 09(之人物动画制作)

上期链接&#xff1a;Unity2D游戏制作入门 | 08-CSDN博客 人物走路动画逻辑补充&#xff08;该帖没有的内容&#xff0c;我给补充了请先看完这帖&#xff0c;再去看补充&#xff09;&#xff1a;人物按下shifit走路动画设定09&#xff08;第九期先行补充&#xff09; 上期我们…

Git之解决重复输入用户名和密码(三十九)

简介&#xff1a; CSDN博客专家&#xff0c;专注Android/Linux系统&#xff0c;分享多mic语音方案、音视频、编解码等技术&#xff0c;与大家一起成长&#xff01; 优质专栏&#xff1a;Audio工程师进阶系列【原创干货持续更新中……】&#x1f680; 优质专栏&#xff1a;多媒…

机器学习--损失函数

损失函数&#xff08;Loss Function&#xff09;&#xff0c;也称为代价函数&#xff08;Cost Function&#xff09;或误差函数&#xff08;Error Function&#xff09;&#xff0c;是机器学习和统计学中的一个重要概念。它用于量化模型预测值与真实值之间的差异。损失函数的值…

Mybatis04-使用注解开发

面向接口编程 面向接口编程 我们之前都学过面向对象编程&#xff0c;也学习过接口&#xff0c;但在真正的开发中&#xff0c;很多时候我们会选择面向接口编程 根本原因 : 解耦 , 可拓展 , 提高复用 , 分层开发中 , 上层不用管具体的实现 , 大家都遵守共同的标准 , 使得开发变…

makefile与进度条

Linux项目自动化构建工具-make/makefile make是一个命令&#xff0c; makefile是一个文件&#xff0c;保存依赖关系和依赖方法。‘ touch Makefile/makefile mybin:mytest.c//依赖关系 目标文件&#xff1a;依赖文件列表 文件列表的文件之间以空格分隔 gcc -o mybin mytest.…

【Javascript系统学习】(二)

函数 定义函数 函数提升仅适用于函数声明&#xff0c;而不适用于函数表达式 函数声明 函数表达式 //例子1 const factorial function fac(n) {return n < 2 ? 1 : n * fac(n - 1); };console.log(factorial(3)); // 6 //factorial(n)、fac(n)、arguments.callee() ----…

【Python】解决Python报错:AttributeError: ‘list‘ object has no attribute ‘shape‘

​​​​ 文章目录 引言1. 错误详解2. 常见的出错场景2.1 使用列表代替NumPy数组2.2 错误的数据类型转换 3. 解决方案3.1 确保使用NumPy数组3.2 检查数据类型 4. 预防措施4.1 使用类型注解4.2 编写单元测试 结语 引言 在使用Python进行数据处理或科学计算时&#xff0c;可能会…