6.4学习总结

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;

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

vscode编译文件夹下所有文件的配置(包含插件和 .json 文件)

文章目录 我所使用的插件.json 文件配置1. c_cpp_properties.json2. launch.json3. settings.json4. tasks.json 如何运行 我所使用的插件 红框中的五个插件是必备的&#xff0c;其中 Code Runner 插件可以在写完一个 .c 或 .cpp 文件后&#xff0c;按下 Crtl R 快捷键快速编…

12-学生们参加各科测试的次数(高频 SQL 50 题基础版)

12-学生们参加各科测试的次数 -- 学生表中&#xff0c;id是唯一的&#xff0c;将他作为主表 -- CROSS JOIN产生了一个结果集&#xff0c;该结果集是两个关联表的行的乘积 -- 2行表,与3行表使用cross join,得到2*36行数据 select st.student_id, st.student_name,su.subject_na…

zdppy_api 中间件请求原理详解

单个中间件的逻辑 整体执行流程&#xff1a; 1、客户端发起请求2、中间件拦截请求&#xff0c;在请求开始之前执行业务逻辑3、API服务接收到中间件处理之后的请求&#xff0c;和数据库交互&#xff0c;请求数据4、数据库返回数据5、API处理数据库的数据&#xff0c;然后给客户…

计算机基础(3)——计算机系统组成

&#x1f497;计算机基础系列文章&#x1f497; &#x1f449;&#x1f340;计算机基础&#xff08;1&#xff09;——计算机的发展史&#x1f340;&#x1f449;&#x1f340;计算机基础&#xff08;2&#xff09;——冯诺依曼体系结构&#x1f340;&#x1f449;&#x1f34…

透视亚马逊云科技中国峰会:生成式AI全面提速,加速行业应用落地

导读&#xff1a;亚马逊云科技在中国&#xff0c;生成式AI与行业化战略齐头并进。 “亚马逊云科技致力于成为企业构建和应用生成式AI的首选。” 近日2024亚马逊云科技中国峰会上&#xff0c;亚马逊全球副总裁、亚马逊云科技大中华区总裁储瑞松分享了亚马逊云科技中国业务最新进…

嵌入式Linux系统编程 — 1.4 原子操作与竞争冒险

目录 1 竞争冒险 1.1 竞争冒险由来 1.2 竞争冒险理解 2 原子操作 2.1 O_APPEND 实现原子操作 2.2 pread()和 pwrite() 2.3 O_EXCL 标志创建文件 1 竞争冒险 1.1 竞争冒险由来 Linux 是一个支持多任务和多用户同时运行的操作系统&#xff0c;它允许多个进程同时执行。…

京东笔试-校招

2022京东数据分析笔试&#xff08;0821&#xff09; 一、选择题&#xff1a;30道 1.解决数据不平衡的方法主要有&#xff08;pca&#xff1f;&#xff09; 2.等频&#xff08;等宽&#xff09;划分问题 3.参数估计&#xff1a;矩估计与极大似然估计的用法&#xff0c;问题分…

kill 不管用时,类型为C

当使用nvidia-smi时看到类型为C的进程时&#xff0c;使用 kill -9 PID&#xff0c;却不管用&#xff0c;这时需要先使用如下命令&#xff0c;找出运行的脚本对应的所有PID: ps -aux | grep train.py 接着就会把train.py对应运行的进程全部展示出来&#xff1a; 接着就是使用 …

25、DHCP FTP

DHCP 动态主机配置协议 DHCP定义&#xff1a; 服务器配置好了地址池 192.168.233.10 192.168.233.20 客户端从地址池当中随机获取一个ip地址&#xff0c;ip地址会发生变化&#xff0c;使用服务端提供的ip地址&#xff0c;时间限制&#xff0c;重启之后也会更换。 DHCP优点&a…

android-JNI

1.2【静态库】的特点&#xff1a; &#xff08;.a&#xff09; ①静态库对函数库的链接是在编译期完成的。执行期间代码装载速度快。 ②使可执行文件变大&#xff0c;浪费空间和资源&#xff08;占空间&#xff09;。 ③对程序的更新、部署与发布不方便&#xff0c;需要全量更新…

【TB作品】msp430g2553单片机,OLED,PCF8591,ADC,DAC

硬件 OLED PCF8591 /** OLED* VCC GND* SCL接P2^0* SDA接P2^1*//** PCF8591* VCC GND* SCL接P1^4* SDA接P1^5*//* 板子上按键 P1.3 *//* 单片机ADC输入引脚 P1.1 *//* 说明&#xff1a;将PCF8591的DAC输出接到单片机ADC输入引脚 P1.1&#xff0c;单片机采集电压并显示 */功能…

Angular 由一个bug说起之六:字体预加载

浏览器在加载一个页面时&#xff0c;会解析网页中的html和css&#xff0c;并开始加载字体文件。字体文件可以通过css中的font-face规则指定&#xff0c;并使用url()函数指定字体文件的路径。 比如下面这样: css font-face {font-family: MyFont;src: url(path/to/font.woff2…

MySQL 关键特性一:插入缓冲、双写缓冲

前言 ​ 本文主要介绍 mysql 的几大特性之几&#xff0c;如&#xff1a;双写缓冲和插入缓存。 双写缓冲 基本概念 ​ 双写缓冲&#xff08;doublewrite buffer&#xff09;是MySQL/InnoDB中用于支持原子页面更新的一种机制。在传统的数据库系统中&#xff0c;为了保证数据的…

C++ XML文件和解析

XML&#xff08;可扩展标记语言&#xff09;是一种用于存储和传输数据的标记语言。它具有自描述性和平台无关性的特点。XML 文档的格式主要由一组嵌套的元素和属性构成&#xff0c;结构清晰&#xff0c;易于理解和解析。 XML 文档的基本格式 一个 XML 文档通常包括以下部分&a…

React 中的 ForwardRef的使用

React 中的 forwardRef Hooks 是指将子组件的 Dom 节点暴露给给父组件&#xff0c;在 React 中如果想要访问 Dom 节点是通过 useRef 这个 hooks&#xff0c;而 forwardHook 在 useRef 做了扩展。useRef 是当前组件中间中的节点&#xff0c;而 forwardRef 相当于做了一层封装将父…

屏幕录制工具分享6款,附上详细电脑录屏教程(2024全新)

当你即将参加一个重要的在线会议或一堂关键的直播课&#xff0c;但又担心错过关键点或无法及时做笔记时&#xff0c;屏幕录制无疑是最好的方法之一。屏幕录制是一项非常有价值的技能&#xff0c;它能让你出于各种目的捕捉屏幕上的活动。无论你的目的是创建教程、演示软件功能、…

重学java 62.IO流 字节流 ③ 字节输入流

告别这种事情&#xff0c;没有道理可讲 —— 24.6.4 一、字节输入流的介绍以及方法的使用 1.概述: 字节输入流 InputStream,是一个抽象类 子类:FileInputStream 2.作用: 读数据,将数据从硬盘上读到内存中来 3.构造: FileInputstream(File file) FileInputstream(String path…

容器中运行ifconfig提示bash: ifconfig: command not found【笔记】

容器中运行ifconfig提示bash: ifconfig: command not found 这个问题是因为在容器中没有安装ifconfig命令。 在容器中安装ifconfig命令&#xff0c;可以使用以下命令&#xff1a; 对于基于Debian/Ubuntu的容器&#xff0c;使用以下命令&#xff1a; apt-get update apt-get …

Spring Boot 使用自定义注解和自定义线程池实现异步日志记录

&#x1f604; 19年之后由于某些原因断更了三年&#xff0c;23年重新扬帆起航&#xff0c;推出更多优质博文&#xff0c;希望大家多多支持&#xff5e; &#x1f337; 古之立大事者&#xff0c;不惟有超世之才&#xff0c;亦必有坚忍不拔之志 &#x1f390; 个人CSND主页——Mi…

leetcode739 每日温度

题目 给定一个整数数组 temperatures &#xff0c;表示每天的温度&#xff0c;返回一个数组 answer &#xff0c;其中 answer[i] 是指对于第 i 天&#xff0c;下一个更高温度出现在几天后。如果气温在这之后都不会升高&#xff0c;请在该位置用 0 来代替。 示例 输入: tempe…