暑假第十五测

题解:

第一题: 

20%枚举长度和每个子串,O(len)判断,随机情况复杂度可过

40%同样枚举长度,然后两个指针卡出区间,O(1)[或O(26)//可能可过?]判断

50%既然知道了40%的做法那么我们可以二分长度就好了

70%二分,需要O(1)判断

100%两个指针维护一个区间,保证左端点固定时,是最小的完美子串

开桶记录每个出现多少次,当一个点新加入或消失时,tot对应改变,tot=26时,更新答案,复杂度O(n) 

#include<bits/stdc++.h>
using namespace std;
const int M = 2e6 + 10;
char a[M];
int len, s[M], vis[28];bool check(int k){int ret = 0;memset(vis, 0, sizeof(vis));for(int i = 1; i <= k; i++){if(!vis[s[i]])ret++;vis[s[i]]++;}if(ret >= 26)return 1;for(int i = k + 1; i <= len; i++){vis[s[i - k]]--;if(!vis[s[i - k]])ret--;if(!vis[s[i]])ret++;vis[s[i]]++;if(ret >= 26)return 1;}return 0;
}int main(){freopen("str.in","r",stdin);freopen("str.out","w",stdout);scanf("%s", a);len = strlen(a);if(len < 26){printf("QwQ\n");return 0;}for(int i = 0; i < len; i++)s[i + 1] = a[i] - 'A';int lf = 26, ans = 0, rg = len;while(lf <= rg){int mid = (lf + rg) >> 1;if(check(mid))ans = mid, rg = mid - 1;else lf = mid + 1;}if(!ans)printf("QwQ\n");else printf("%d\n",ans);
}
View Code

 

第二题:

将两个数相乘,看一看是不是一个数的立方,我们可以把游戏压缩成两局,变成X1^1 * X2^1 * …… * Yn-1 ^2 * Yn^2  X1 ^ 2 * X2 *^ 2 * ……* Yn-1 ^ 1 * Yn ^1,  所以他一定是一个数k的三次方; 再看拆出来的k是不是x, y 的因数

#include<bits/stdc++.h>
using namespace std;
const int N = 1e5 + 1;
#define ll long long
ll x, y;
bool check(){ll tmp = x * y;ll lf = 1, ans = 0, rg = min(sqrt(tmp), 1e6);while(lf <= rg){ll mid = (lf + rg) >> 1;ll cc = mid * mid * mid;if(cc == tmp) {ans = mid; return (x % mid == 0 && y % mid == 0);}if(cc < tmp)lf = mid + 1;else rg = mid - 1; }return 0;
}
int main(){freopen("game.in","r",stdin);freopen("game.out","w",stdout);int T;scanf("%d", &T);while(T--){scanf("%I64d%I64d", &x, &y);if(check())puts("Yes");else puts("No");}
}
View Code

 

第三题:

不能盖住好地,那么宽为1的木板只能放在行、列连通块里。

•所以行、列连通块对应左、右部中的点,泥地对应边。

•求二分图最小覆盖就是答案。

二分图最小点覆盖==最大匹配

#include<bits/stdc++.h>
using namespace std;
const int M = 101;char c[M][M];
int mp[M][M];
bool vis[M*M*2];
int head[M*M*2], h[M][M], r[M*M*2], l[M][M], lf[M*M], num, tot, match[M*M*2];
struct edge{int v, nxt;}G[M*M*2];
void add(int u, int v){G[++tot].nxt = head[u]; head[u] = tot; G[tot].v = v;}bool find(int u){for(int i = head[u]; i; i = G[i].nxt){int v = G[i].v;if( !vis[v] ){vis[v] = 1;if(!match[v] || find(match[v])){match[v] = u; return 1;}}}return 0;
}int main(){freopen("cover.in","r",stdin);freopen("cover.out","w",stdout);int R, C, ans = 0, cnt = 0;scanf("%d%d", &R, &C);for(int i = 1; i <= R; i++)scanf("%s", c[i]);for(int i = 1; i <= R; i++)for(int j = 0; j < C; j++){if(c[i][j] =='*')mp[i][j + 1] = 1;//, id[i][j + 1] = ++num;
        }for(int i = 1; i <= R; i++)for(int j = 1; j <= C; j++){if(!h[i][j]){++num;for(int k = j; k <= C && mp[i][k]; k++){h[i][k] = num; //add(id[i][k], num);
                }}if(!l[i][j]){++num;for(int k = i; k <= R && mp[k][j]; k++){l[k][j] = num; //add(id[k][j], num);
                }}}for(int i = 1; i <= R; i++)for(int j = 1; j <= C; j++)if(mp[i][j]){add(h[i][j], l[i][j]);if(!r[h[i][j]]){lf[++cnt] = h[i][j];r[h[i][j]] = 1;}}for(int i = 1; i <= cnt; i++){memset(vis, 0, sizeof(vis));if(find(lf[i]))ans++;}printf("%d\n", ans);
}
View Code

 

转载于:https://www.cnblogs.com/EdSheeran/p/9489752.html

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

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

相关文章

zabbix磁盘的自动发现与磁盘指标监控

由于最近项目上需要对服务器监控进行规范化监控&#xff0c;再磁盘这块有几种方式 1.如果每台设备的磁盘是一样的 比如都有vda,vdb两块磁盘那么可以采用 1.1 每台客户端写脚本&#xff0c;服务端每台设备去加上监控项&#xff08;------最次的手段-------------&#xff09; 1.…

php前台用户权限开通,vue实现网站前台的权限管理

本文主要介绍了基于vue实现网站前台的权限管理(前后端分离实践)&#xff0c;小编觉得挺不错的&#xff0c;现在分享给大家&#xff0c;也给大家做个参考。一起跟随小编过来看看吧&#xff0c;希望能帮助到大家。Javascript做为当下的热门语言&#xff0c;用途很广泛&#xff0c…

应用ForkJoin –从最佳到快速

到目前为止&#xff0c;JDK 7已很好地掌握在开发人员手中&#xff0c;并且大多数人都听说过ForkJoin&#xff0c;但是没有多少人有时间或机会去尝试它。 它引起了&#xff0c;并且可能仍然引起一些混乱&#xff0c;与普通线程池有什么不同。 [1] 我在本文中的目标是通过一个代…

Echarts-K线图提示框改头换面

工作&#xff1a; 使用Hbuilder建web工程&#xff0c;加入echarts相关库&#xff0c;根据需要更改K线图及其的提示样式&#xff0c;去除默认提示&#xff0c;使用异步加载echarts的数据&#xff0c;数据格式为json。 需要注意的K线图和5日均线&#xff0c;10日均线的意义&#…

vc6.0 matlab混合编程,matlab2010 + vc6.0混合编程实例(调用dll)

不想解释太多直接上代码吧&#xff01;&#xff01;&#xff01;在对matlab配置后&#xff0c;上代码mcc -W cpplib:libMyAdd -T link:lib MyAdd -C就可以了&#xff0c;记得加上-C在对VC6.0进行配置的时候只要把 matlabroot\extern\include和matlabroot\extern\lib\win32\micr…

canvas换图时候会闪烁_Canvas实现图片上标注、缩放、移动和保存历史状态,纯干货(附CSS 3变化公式)...

(给前端大学加星标&#xff0c;提升前端技能.)作者&#xff1a;zhcxk1998https://juejin.im/user/5d4304bdf265da03d15531dc哈哈哈俺又来啦&#xff0c;这次带来的是canvas实现一些画布功能的文章&#xff0c;希望大家喜欢&#xff01;这个css3变化公式可以适用于平常我们使用的…

RMI强制Full GC每小时运行一次

在我职业生涯中进行的所有故障排除练习中&#xff0c;我感到随着时间的推移&#xff0c;我所追寻的错误在不断发展&#xff0c;变得越来越卑鄙和丑陋。 也许仅仅是我的年龄开始了。这个特别的Heisenbug –看起来像这篇帖子一样&#xff0c;再次让我清醒了很多&#xff0c;而不是…

oracle 安装ora 27102,ORA-27102 解决办法

因为在32位操作系统上执行了如下的操作alter system set sga_max_size2G scopespfile;之后再重启数据库就会失败报出错误:ORA-27102Out of Memory解决的方法也很简单:新建一个文本文件 如initaaa.ora内容&#xff1a;SPFILE../product/10.2.0&#xff0f;db_1/dbs/spfileorcl.o…

Codechef August Challenge 2018 : Modular GCD

传送门 一开始还手动拓欧找规律&#xff0c;发现好像玩不了。 然后想了想&#xff0c;A-B这个数比较小&#xff0c;枚举它的因子判断合不合法就行了。 需要特判AB的情况。 #include<cstdio> #include<algorithm> #define ll long long #define ld long double usin…

c语言 指针_C语言——指针

学习阶段&#xff1a;高中信竞、大学编程。前置知识&#xff1a;二进制与十六进制&#xff0c;C语言基础&#xff0c;数组。指针初学可能比较难理解&#xff0c;我这篇文章尽量用通俗易懂的方式来讲解。1. 指针概述为什么有指针这个东西&#xff1f;因为指针很贴近计算机内部的…

BZOJ 2141 排队(分块+树状数组)

题意 第一行为一个正整数n&#xff0c;表示小朋友的数量&#xff1b;第二行包含n个由空格分隔的正整数h1,h2,…,hn&#xff0c;依次表示初始队列中小朋友的身高&#xff1b;第三行为一个正整数m&#xff0c;表示交换操作的次数&#xff1b;以下m行每行包含两个正整数ai和bi&…

vant input框禁止调用手机键盘_【案例分享】适应网银等密码键盘的解决方案

在各种技术不断进步的大趋势下&#xff0c;对业务造成了极大影响&#xff0c;从大数据到云计算&#xff0c;再到人工智能&#xff0c;众多企业都开始步入技术改革&#xff0c;从而实现企业的创新。但与此同时&#xff0c;更多技术的引用&#xff0c;意味着更多的业务系统上线&a…

启动oracle数据库工具,Oracle数据库常用工具

SQL*Plus:SQL*Plus 是Oracle 数据库的一个基本工具&#xff0c;它允许用户使用SQL 命令交互式的访问数据库&#xff0c;也允许用户使用SQL*Plus 命令格式化输出参数。 通过SQL*Plus &#xff0c;可以完成数据库的启动和停止、创建和运行查询、更新数据、格式化输出数据报表、运…

Java 获取linux根目录下的文件夹_Windows支持直接访问Linux子系统文件:你的下一台Linux何必是Linux...

2020年第一波薅当当网羊毛的机会&#xff0c;别错过&#xff01;晓查 发自 凹非寺 量子位 报道 | 公众号 QbitAI 微软&#xff0c;致力于做最好的Linux发行版。今天&#xff0c;安装Windows 10测试版本号19603的用户发现&#xff0c;系统里WSL (Windows中的Linux子系统…

HTML5效果:实现树叶飘落

实现如图所示的东西效果&#xff08;落叶下落&#xff09;&#xff1a; html代码&#xff1a; <!DOCTYPE html><html><head><title>HTML5树叶飘落动画</title><meta charset"utf-8"><meta name"viewport" content&…

oracle 创交表,创建交叉报表(oracle)_oracle

创建交叉报表create table t1(goodid number(10) not null,saledate date not null,salesum number(10));要求生成本年度每个月的产品销售状况表m1 m2 m3 ... m12g1g2...gn下面是生成报表的sqlSELECT goodid,SUM(decode(to_char(saledate,mm),01,salesum)) "01"…

cass方格网数据excel_讨论|CASS怎么计算回字型土方? 124

大家好,欢迎来到我的专栏。这是我原创的第124篇CASS应用技术干货文章。希望对你有所帮助&#xff0c;写文不易&#xff0c;请点赞哦!回字型土方工程&#xff0c;就是计算区域内部&#xff0c;有一个或多个不参加计算的区域&#xff0c;这种区域也就是常说的“扣岛”。常见的有基…

垃圾收集器准则和提示

这些是我需要调整GC时通常会看到的一些准则和技巧。 主要由以下两本书组成&#xff0c;而根据我的经验却很少&#xff1a; Java性能 JBoss AS 5性能调优 希望它们对那里的其他人有用&#xff01; 垃圾收集器 XX:AggressiveOpts将HotSpot内部布尔变量设置为true以启用其他性…

MD5加密处理

MD5 加密后的位数一般为两种&#xff0c;16 位与 32 位。16 位实际上是从 32 位字符串中&#xff0c;取中间的第 9 位到第 24 位的部分 using System; using System.Security.Cryptography; using System.Text;namespace _04MD5加密 {internal class Program{private static vo…

移动前端—H5实现图片先压缩再上传

在做移动端图片上传的时候&#xff0c;用户传的都是手机本地图片&#xff0c;而本地图片一般都相对比较大&#xff0c;拿iphone6来说&#xff0c;平时拍很多图片都是一两M的&#xff0c;如果直接这样上传&#xff0c;那图片就太大了&#xff0c;如果用户用的是移动流量&#xf…