【算法每日一练]-练习篇 #Tile Pattern #Swapping Puzzle # socks

目录

 今日知识点:

二维前缀和

逆序对

袜子配对(感觉挺难的,又不知道说啥)    

Tile Pattern

Swapping Puzzle 

socks


        

        

Tile Pattern

331

题意:有一个10^9*10^9的方格。W表示白色方格,B表示黑色方格。每个(i,j)方的颜色由(i%n,j%n) 决定。我们给出n*n的字符阵列。进行q此查询。每次输入两个坐标,找出矩形区域内的黑色方格数量。

输入:

样例解释: 

 

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=1024;
int n,dp[N][N];ll f(int x,int y){ll ret=1ll*(x/n)*(y/n)*dp[n][n];//先计算完整的块,左上角ret+=dp[x%n][y%n];//右下角ret+=1ll*dp[x%n][n]*(y/n);//左下角ret+=1ll*dp[n][y%n]*(x/n);//右上角return ret;
}
int main(){int q;cin>>n>>q;char p[N][N];for(int i=1;i<=n;i++){for(int j=1;j<=n;j++){//从(1,1)开始初始化cin>>p[i][j];dp[i][j]=(p[i][j]=='B')+dp[i-1][j]+dp[i][j-1]-dp[i-1][j-1];}}while(q--){int a,b,c,d;cin>>a>>b>>c>>d;c++;d++;cout<<f(c,d)-f(a,d)-f(c,b)+f(a,b)<<'\n';}
}

        

         

         

Swapping Puzzle 

332D

题意:给你两个h*w的数字阵列,问是否可以经过以下操作将第一个阵列变成第二个阵列,如果可以输出最小操作次数,如果不能输出-1.

操作1:交换相邻的两行

操作2:交换相邻的两列

思路:

其实交换的本质就是把列号和行号交换了,目前阵列对应的行号如下图所示。

那么很明显,如果这个行号和列号是完全正确的,那么a2[1][2]等于a1[1][3],a2[2][1]等于a1[3][1],你发现只要a2的逻辑坐标和a1的逻辑值的坐标对应数字一样,那么这个行列号就是正确的。那么行列号完全可以直接暴力枚举并存起来的。然后进行判断,看看这个行列号是否和目标阵列的相符合。最后求最少得交换次数,就是求逆序对数即可(之前讲过这个问题)。

         

#include <bits/stdc++.h>
using namespace std;
int a1[6][6],a2[6][6],b1[250][6],b2[250][6];
int h,w,tot1,tot2,vis[10],tmp[10];void dfs1(int k){if(k>h){memcpy(b1[++tot1],tmp,sizeof(tmp));return ;}for(int i=1;i<=h;i++){if(vis[i])continue;vis[i]=1;tmp[k]=i;dfs1(k+1);vis[i]=0;}
}
void dfs2(int k){if(k>w){memcpy(b2[++tot2],tmp,sizeof(tmp));return ;}for(int i=1;i<=w;i++){if(vis[i])continue;vis[i]=1;tmp[k]=i;dfs2(k+1);vis[i]=0;}
}
bool check(int k1,int k2){int i=1,j=1;while(1){if(a1[b1[k1][i]][b2[k2][j]]==a2[i][j])j++;//看看逻辑位置和实际位置的数字是否一样else return 0;if(j==w+1)i++,j=1;if(i>h)return 1;}
}
int main(){cin>>h>>w;for(int i=1;i<=h;i++)for(int j=1;j<=w;j++){cin>>a1[i][j];//输入原始阵列}for(int i=1;i<=h;i++)for(int j=1;j<=w;j++){cin>>a2[i][j];//输入目标阵列}int f=0;for(int i=1;i<=h;i++)//特判for(int j=1;j<=w;j++)if(a1[i][j]!=a2[i][j]){f=1;break;}if(f==0){cout<<0;return 0;}//预处理两行数字的全排列memset(vis,0,sizeof(vis));dfs1(1);memset(vis,0,sizeof(vis));dfs2(1);//进行行和列的匹配int ans=1e8;for(int i=1;i<=tot1;i++)for(int j=1;j<=tot2;j++){if(check(i,j)){//看看是否匹配int an=0;for(int p=1;p<=h-1;p++){int t=p+1;while(t<=h){//统计逆序对数if(b1[i][p]>b1[i][t])an++;t++;}	  }for(int p=1;p<=w-1;p++){int t=p+1;while(t<=w){if(b2[j][p]>b2[j][t])an++;t++;}	  }if(an)ans=min(ans,an);//如果方案更新了,更新最优答案}}if(ans!=1e8)cout<<ans;//输出答案else cout<<-1;
}

         

        

socks

334C

题意:一共有n对袜子第i对颜色都是i。但是不小心丢了k只,每只颜色是a1,a2……ak,我们打算把剩下的2n-k只袜子组成[(2n-k)/2]对。每对袜子的奇怪程度是|i-j|(i,j是两个袜子的颜色)。问袜子的奇怪程度和最小是多少?(注意袜子可能有剩余,剩余的袜子不穿所以没有奇怪程度)

(1<k<n<2*10^5)

输入:     输出:2

4 2
1 3

样例解释:现在仅剩下1,2,2,3,4,4,然后 (1,2),(2,3),(4,4)  对应奇怪程度和∣1−2∣+∣2−3∣+∣4−4∣=2

思路:

主要思路就是贪心。我们可以将袜子给从小到大进行排序。然后注意到对于1,2,2,3无论是(1,2)(2,3)还是(1,3)(2,2)都是一样的(可以理解成一条线段分成了两端)。也就是说同色的袜子我们放在一起才是最优的。

那么就只需要处理剩余的k个袜子就行了。如果说k是偶数就很好做,直接前后两两组合就行。

如果k是奇数,就要考虑丢掉某一个袜子。丢掉的袜子一定可以使得最终的奇怪程度最小。那么也就是我们要暴力尝试丢掉每一只袜子试试 。但是O(n^2)万万不行。

好,下面就有点玄学了。首先丢掉的袜子一定是奇数的位置。

如图:

因为偶数的位置一定刚好可以和前面的奇数位置匹配,如果丢掉偶数的位置,前面的位置必然有一个多出来的,然后只能和后面的匹配,那么奇怪程度必然会更大,这一定不是最优解。

只有丢掉奇数位置,因为前面和后面都是偶数个,恰好匹配,不会出现跨过丢掉的袜子去和别人匹配的情况。所以只能丢奇数位置的袜子。

假设我们在从后向前模拟枚举时,你会发现我们是跳着走的,右边每次都恰好多出一对,前面恰好减少一对,剩余的都不变,好——>前缀和优化。这样就能降到O(n)了。然后计算最优答案即可 

#include <bits/stdc++.h>
using namespace std;
int a[300000];
long long ans;
int main(){int n,k;cin>>n>>k;for(int i=0;i<k;i++)cin>>a[i];if(k&1){vector<ll> suf(k);//定义前缀和suf,suf[0]表示前一个,suf[2]表示前两个(0,1),suf[4]表示前四个(0,1,2,3),suf[k-1]表示前k-1个(0~k-2)for(int i=1;i<k;i+=2){//k一定是奇数,所以从1开始遍历,一直遍历到k-2,那么suf就到suf[k-1]suf[i+1]=a[i]-a[i-1];if(i>1) suf[i+1]+=suf[i-1];}ans=suf[k-1];//k-1个袜子的前缀和(0~k-2号袜子),这种情况对应最后一个袜子丢掉的答案int now=0;for(int i=k-2;i>=0;i-=2){//k-2是奇数now+=a[i+1]-a[i];//加上右边不断多出来的袜子对ans=min(ans,now+suf[i-1]);}}else {for(int i=1;i<k;i+=2){//k是偶数时候,k-1是奇数,刚好全部配对ans+=a[i]-a[i-1];}}cout<<ans;
}

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

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

相关文章

还不会python 实现常用的数据编码和对称加密?看这篇文章就够啦~

相信很多使用 python 的小伙伴在工作中都遇到过&#xff0c;对数据进行相关编码或加密的需求&#xff0c;今天这篇文章主要给大家介绍对于一些常用的数据编码和数据加密的方式&#xff0c;如何使用 python 去实现。话不多说&#xff0c;接下来直接进入主题&#xff1a; 前言 1…

phpstorm配置ftp

1 选择设置ftp 2设置自动上传

使用FFmpeg+EasyDarwin搭建音视频推拉流测试环境

1. 前言 在上一篇文章《使用VS2017在win10 x64上编译调试FFmpeg&#xff08;附源码和虚拟机下载&#xff09;》中&#xff0c;我们讲解了如何搭建FFmpeg源码编译和调试环境。 调试FFmpeg&#xff0c;还需要搭建流媒体服务器。流媒体服务器的作用是通过网络对外提供音视频服务…

CentOS本地部署SQL Server数据库无公网ip环境实现远程访问

文章目录 前言1.安装GeoServer2. windows 安装 cpolar3. 创建公网访问地址4. 公网访问Geo Servcer服务5. 固定公网HTTP地址 前言 GeoServer是OGC Web服务器规范的J2EE实现&#xff0c;利用GeoServer可以方便地发布地图数据&#xff0c;允许用户对要素数据进行更新、删除、插入…

简单易懂的PyTorch激活函数大全详解

目录 torch.nn子模块Non-linear Activations nn.ELU 主要特点与注意事项 使用方法与技巧 示例代码 图示 nn.Hardshrink Hardshrink函数定义 参数 形状 示例代码 图示 nn.Hardsigmoid Hardsigmoid函数定义 参数 形状 示例代码 图示 nn.Hardtanh HardTanh函数…

【QML COOK】- 006-用C++定义一个QML元素类型

Qt原本是一个C图形框架&#xff0c;因此QML也少不了C。QML通常只负责显示&#xff0c;而后台逻辑由C实现&#xff0c;因此掌握C和QML之间的交互非常必要。 本例实现一个最简单的例子&#xff0c;用C定义一个QML的元素类型并在QML使用它。 需求是在窗口上显示鼠标点击的次数。…

19道ElasticSearch面试题(很全)

点击下载《19道ElasticSearch面试题&#xff08;很全&#xff09;》 1. elasticsearch的一些调优手段 1、设计阶段调优 &#xff08;1&#xff09;根据业务增量需求&#xff0c;采取基于日期模板创建索引&#xff0c;通过 roll over API 滚动索引&#xff1b; &#xff08;…

01-你好Python-python环境安装 python解释器的安装 pycharm的安装

python环境安装 官方网址&#xff1a;https://python.org 这里可以下载最新版本的&#xff0c;下载完成以后在自己的浏览器文件下载的文件夹中找到该文件 下载速度可能会比较慢&#xff0c;这里已经提供好了文件&#xff0c;可以直接点击安装 点击Customize installation 点击…

PCL 格网法计算点云的占地面积

目录 一、算法原理二、代码实现三、结果展示四、测试数据本文由CSDN点云侠原创,原文链接。如果你不是在点云侠的博客中看到该文章,那么此处便是不要脸的爬虫与GPT生成的文章。 一、算法原理 该方法主要用于粗略统计机载点云的占地面积。方法原理是将点云沿 X O Y XOY

渐进增强与优雅降级:提升用户体验的双重策略

&#x1f90d; 前端开发工程师&#xff08;主业&#xff09;、技术博主&#xff08;副业&#xff09;、已过CET6 &#x1f368; 阿珊和她的猫_CSDN个人主页 &#x1f560; 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 &#x1f35a; 蓝桥云课签约作者、已在蓝桥云…

外包做了5个月,技术退步一大半了。。。

先说一下自己的情况&#xff0c;本科生&#xff0c;20年通过校招进入深圳某软件公司&#xff0c;干了接近4年的功能测试&#xff0c;今年年初&#xff0c;感觉自己不能够在这样下去了&#xff0c;长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了四年的功能测试…

23111 IO进程线程 day8

使用信号灯集完成三个进程的同步&#xff0c;A进程输出字符A&#xff0c;B进程输出字符B&#xff0c;C进程输出字符C&#xff0c;要求输出结果为ABCABCABCABCABC... #include<myhead.h> #include "sem.h"int main(int argc, const char *argv[]) {pid_t pid…

救赎之道,就在其中

时光荏苒&#xff0c;不知不觉距离我踏入职场的第一天已经快一年了。最近也是看到平台举办年度征文活动&#xff0c;借此契机重新审视自己这两年来的成长历程&#xff0c;也希望对正在迷茫的人提供一些精神上的慰藉。 1.对未来的迷茫 如果要给两年前的自己打上标签&#xff0…

【Linux Shell】7. printf 命令

文章目录 【 1. printf 命令的使用方法 】【 2. 实例 】2.1 printf 换行/不换行的区别2.2 格式化控制输出2.3 引号对输出的影响2.4 参数数量对输出的影响 【 1. printf 命令的使用方法 】 printf 命令模仿 C 程序库&#xff08;library&#xff09;里的 printf() 程序&#xf…

python flask图书管理系统带文档

python flask图书管理系统带文档。功能&#xff1a;登录&#xff0c;图书的增删改查&#xff0c;读者管理&#xff0c;借阅记录&#xff0c;有文档。 技术&#xff1a;python3,flask,mysql,html。 包含源码数据库文件文档。 源码下载地址&#xff1a; https://download.csd…

Python画国旗

前言 今天&#xff0c;我们来用turtle库来绘制国旗 一、美国国旗 国旗的形状是长方形;国旗的长宽之比为19:10&#xff0c;美国国旗由红、白、蓝三色组成;画面格局由两部分组成&#xff0c;旗的左上方蓝底上排列着50颗白色的星&#xff0c;6颗一排与5颗一排相间排列&#xff…

Fluids —— Minimal fluid setups

目录 Waterline FLIP Boundary Boundary flow 创建流体设置的三个基本方法&#xff1b; Waterline 由FLIP Container SOP与FLIP Solver SOP组成的基本network&#xff0c;可不需要任何外部源&#xff1b; FLIP Container SOP&#xff0c;能使用不同的容器形状&#xff1b;F…

【SQL】对表中的记录通过时间维度分组,统计出每组的记录条数

场景&#xff1a;一般用作数据统计&#xff0c;比如统计一个淘宝用户在年、月、日的维度上的订单数。 业务&#xff1a;一个集合&#xff0c;以时间维度来进行分组求和。 准备一张订单表order&#xff0c;有一些常规属性&#xff0c;比如创建时间&#xff0c;订单号。 DDL语句如…

一文了解Git(所有命令)附带图片

我是南城余&#xff01;阿里云开发者平台专家博士证书获得者&#xff01; 欢迎关注我的博客&#xff01;一同成长&#xff01; 一名从事运维开发的worker&#xff0c;记录分享学习。 专注于AI&#xff0c;运维开发&#xff0c;windows Linux 系统领域的分享&#xff01; 其他…

国产AI工具钉钉AI助理:开启个性化助手服务的新篇章

钉钉AI助理是钉钉平台的一项功能&#xff0c;它可以根据用户的需求提供个性化的AI助手服务。用户可以在AI助理页面一键创建个性化的AI助理&#xff0c;如个人的工作AI助理、旅游AI助理、资讯AI助理等。企业也可以充分使用企业所沉淀的知识库和业务数据&#xff0c;在获得授权后…