【算法每日一练]-练习篇 #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.mzph.cn/news/611853.shtml

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

相关文章

Unity真机Log工具 SRDebugger使用记录,GM布局管理

SRDebugger 官方文档安装及初始化常用设置选项布局选项快捷键选项高级设置 使用GM工具案例常用特性GM分组排序GM固定页签 官方文档 文档&#xff1a; https://www.stompyrobot.uk/tools/srdebugger/documentation/ 插件地址&#xff1a; https://assetstore.unity.com/package…

数据结构及单链表例题(下)

上次我们已经了解了单链表的数据结构定义以及创建单链表的两种方法,这节介绍几道例题. 文章目录 前言 一、已知L为带头结点的单链表,请依照递归思想实现下列运算 二、单链表访问第i个数据节点 三、在第i个元素前插入元素e 四、删除第i个结点 五、查找带头结点单链表倒数第…

TS 36.322 V12.0.0-过程

​本文的内容主要涉及TS 36.322&#xff0c;版本是C00&#xff0c;也就是V12.0.0。

构建安全可靠的系统:第十一章到第十五章

第三部分&#xff1a;实现系统 原文&#xff1a;Part III. Implementing Systems 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 一旦您分析并设计了您的系统&#xff0c;就该是实现计划的时候了。在某些情况下&#xff0c;实现可能意味着购买现成的解决方案。第十一章…

QT第1天

题目&#xff1a;点击按钮改变文字 需要增加一个count属性&#xff0c;并且只需要定义槽&#xff0c;信号函数已经内置好了 //widget.h#ifndef WIDGET_H #define WIDGET_H#include <QWidget>QT_BEGIN_NAMESPACE namespace Ui { class Widget; } QT_END_NAMESPACEclass Wi…

[C++]多态

目录 C多态&#xff1a;&#xff1a; 多态的概念 多态的定义及实现 多态的构成条件 虚函数 虚函数的重写 虚函数重写的特例 C11 override和final 重载、重写重定义的对比 抽象类 概念 接口继承和实现继承 多态的原理 虚函数表 多态的原理 动态绑定和静态绑定 单继承和…

LeetCode 84:柱状图中的最大矩形

一、题目描述 给定 n 个非负整数&#xff0c;用来表示柱状图中各个柱子的高度。每个柱子彼此相邻&#xff0c;且宽度为 1 。 求在该柱状图中&#xff0c;能够勾勒出来的矩形的最大面积。 示例 1: 输入&#xff1a;heights [2,1,5,6,2,3] 输出&#xff1a;10 解释&#xff1a…

Jmeter+ant+Jenkins 接口自动化框架完整版

接口自动化测试单有脚本是不够的&#xff0c;我们还需要批量跑指定接口&#xff0c;生成接口运行报告&#xff0c;定位报错接口&#xff0c;接口定时任务&#xff0c;邮件通知等功能。批量跑指定接口&#xff1a;我们可以利用ant批量跑指定目录下的Jmeter脚本生成接口运行报告&…

vue3基础类型和引用类型,和store的使用

案例一&#xff1a; 如果我在store创建一个变量&#xff0c;是读取缓存key为name的数据&#xff0c; store.name 默认值是张三 # 声明一个变量 const title ref(store.name) # 然后修改title.value "李四"&#xff0c; # 问&#xff1a;打印store.name&#xff0…

怎么投稿各大媒体网站?

怎么投稿各大媒体网站&#xff1f;这是很多写作者及自媒体从业者经常面临的问题。在信息爆炸的时代&#xff0c;如何将自己的文章推送到广大读者面前&#xff0c;成为了一个不可避免的挑战。本文将为大家介绍一种简单有效的投稿方法——媒介库发稿平台发稿&#xff0c;帮助大家…

5,sharding-jdbc入门-sharding-jdbc广播表

执行sql #在数据库 user_db、order_db_1、order_db_2中均要建表 CREATE TABLE t_dict (dict_id BIGINT (20) NOT NULL COMMENT 字典id,type VARCHAR (50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL COMMENT 字典类型,code VARCHAR (50) CHARACTER SET utf8 COLLAT…

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

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

C#入门篇(一)

变量 顾名思义就是变化的容器&#xff0c;即可以用来存放各种不同类型数值的一个容器 折叠代码 第一步&#xff1a;#region 第二步&#xff1a;按tab键 14种数据类型 有符号的数据类型 sbyte&#xff1a;-128~127 short&#xff1a;-32768~32767 int&#xff1a;-21亿多~21亿多…

CHS_01.2.1.1+2.1.3+进程的概念、组成、特征

CHS_01.2.1.12.1.3进程的概念、组成、特征 进程进程的概念 进程的组成——PCB进程的组成——PCB进程的组成——程序段、数据段知识滚雪球&#xff1a;程序是如何运行的&#xff1f;进程的组成进程的特征 知识回顾与重要考点 从这个小节开始 我们会正式进入第二章处理机管理相关…

封装动画函数

文章目录 需求分析确定参数确定属性值具体实现简单扩展 需求分析 在 css 中&#xff0c;如果要给一个元素设置动画&#xff0c;就要改变一个css属性&#xff0c;也是一个值到另外一个值的变化&#xff0c;但是放入到我们这里的动画函数里面&#xff0c;我是不知道是具体要用到…

STK 特定问题建模(五)频谱分析(第二部分)

文章目录 简介三、链路分析3.1 星地链路干扰分析3.2 频谱分析 简介 本篇对卫星通信中的频谱利用率、潜在干扰对频谱的影响进行分析&#xff0c;以LEO卫星信号对GEO通信链路影响为例&#xff0c;分析星地链路频谱。 建模将从以下几个部分开展&#xff1a; 1、GEO星地通信收发机…

Java接口的解析

在 Java 中&#xff0c;接口&#xff08;Interface&#xff09;是一种抽象类型&#xff0c;用于定义一组相关方法的契约。接口只包含方法的签名&#xff0c;而没有方法的实现。实现接口的类必须提供接口中定义的方法的具体实现。 以下是对 Java 接口的解析&#xff1a; 这只是…

使用Scikit Learn 进行识别手写数字

使用Scikit Learn 进行识别手写数字 作者&#xff1a;i阿极 作者简介&#xff1a;数据分析领域优质创作者、多项比赛获奖者&#xff1a;博主个人首页 &#x1f60a;&#x1f60a;&#x1f60a;如果觉得文章不错或能帮助到你学习&#xff0c;可以点赞&#x1f44d;收藏&#x1f…

MySql -数据库进阶

一、约束 1.外键约束 外键约束概念 让表和表之间产生关系&#xff0c;从而保证数据的准确性&#xff01; 建表时添加外键约束 为什么要有外键约束 -- 创建db2数据库 CREATE DATABASE db2; -- 使用db2数据库 USE db2;-- 创建user用户表 CREATE TABLE USER(id INT PRIMARY KEY …

2024-01-09 Android.mk 根据c文件名插入特定的宏定义,我这里用于定义log LOG_TAG 标签

一、在Android的构建系统中&#xff0c;使用Android.mk构建脚本可以根据特定需求来定义宏。如果你想根据C文件的名称来插入特定的宏定义&#xff0c;可以使用条件语句检查文件名&#xff0c;并相应地设置宏。 在Android的构建系统中&#xff0c;使用Android.mk构建脚本可以根据…