Educational Codeforces Round 20 A-E

文章目录

    • A. Maximal Binary Matrix
    • B. Distances to Zero
    • C. Maximal GCD
    • D. Magazine Ad
    • E. Roma and Poker

A. Maximal Binary Matrix

思路:一道很有意思的构造,我们可以发现,按照下述,从外到内进行一层一层的构造一定是最优的。在这里插入图片描述

#include <bits/stdc++.h>

using namespace std;
const int N = 1e5 + 5;
typedef long long ll;
typedef pair<ll, ll> pll;
typedef array<ll, 3> p3;
int mod = 1e9+7;
const int maxv = 4e6 + 5;
// #define endl "\n"

int a[105][105];
int n,k;
void solve()
{

	cin>>n>>k;
	if(k>n*n){
		cout<<-1<<endl;
		return ;
	}
	int f=0;
	for(int i=1;i<=n;i++){
		for(int j=1;j<=n;j++){
			if(k==0) {
				f=1;
				break;
			}
			if(a[i][j]) continue;
			if(i==j) a[i][j]=1,k--;
			else{
				if(k>=2) a[i][j]=a[j][i]=1,k-=2;
			}
		}
		if(f) break;
	}
	for(int l=1;l<=n;l++){
		for(int r=1;r<=n;r++) cout<<a[l][r]<<" ";
		cout<<endl;
	}
}

int main()
{
    ios::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);
	int t;
	t=1;
	// cin>>t;
	while(t--){
		solve();
	}
   	system("pause");
    return 0;
}

B. Distances to Zero

给你一个由整数 a0, a1, …, an - 1 组成的数组。求每个元素到最近的零的距离(到等于零的元素的距离)。给定数组中至少有一个零元素。

思路:我们考虑除了首尾元素和0的距离,若其左方存在0,并且右方存在0,那么我们可以从前往后扫一遍,然后从后往前扫一遍,就可以求出每个元素到0的最短距离。

#include <bits/stdc++.h>

using namespace std;
const int N = 2e5 + 5;
typedef long long ll;
typedef pair<ll, ll> pll;
typedef array<ll, 3> p3;
int mod = 1e9+7;
const int maxv = 4e6 + 5;
// #define endl "\n"

int ans[N];

void solve()
{
	int n;
	cin>>n;
	vector<int> a(n+5);
	memset(ans,0x3f,sizeof ans);
	for(int i=1;i<=n;i++) cin>>a[i];
	int last=-1;
	for(int i=1;i<=n;i++){
		if(a[i]==0){
			ans[i]=0,last=i;
		}
		if(last==-1) continue;
		else{
			ans[i]=(i-last);
		}
	}
	last=-1;
	for(int i=n;i>=1;i--){
		if(a[i]==0){
			ans[i]=0,last=i;
		}
		if(last==-1) continue;
		else{
			ans[i]=min(ans[i],last-i);
		}
	}
	for(int i=1;i<=n;i++) cout<<ans[i]<<" ";
	cout<<endl;
}

int main()
{
    ios::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);
	int t;
	t=1;
	// cin>>t;
	while(t--){
		solve();
	}
   	system("pause");
    return 0;
}

C. Maximal GCD

给你一个正整数 n 。你应该创建这样一个由 k 个正数 a1, a2, …, ak 组成的 严格递增序列,使它们的和等于 n ,且最大公约数为最大值。

数列的最大公约数是数列中每个元素都能被它们整除的数的最大值。

如果不存在可能的序列,则输出 -1.

思路:感觉不能随便构造出来,所有考虑对于数列的最大公约数进行枚举,然后取最大的合法序列即可,但暴力枚举 1 − n 1-n 1n肯定会超时,考虑优化,我们会发现,整个数列的最大公约数,一定是n的因子。

证明:设最大公因数为 k ,那么我们构造最小的严格递增序列为 k ∗ 1 , k ∗ 2 , k ∗ 3...... k ∗ ( i − 1 ) , k ∗ i k*1,k*2,k*3......k*(i-1),k*i k1,k2,k3......k(i1),ki,其和等于 k ,那么把 k 提出来,就得到 n / k 为一个常数,因此得证。

又因为 n 的范围为1e10,枚举因数的时间复杂度为 n \sqrt{n} n ,所以只需要对 n 进行质因数分解,然后一一枚举取最大值即可。

#include <bits/stdc++.h>

using namespace std;
const int N = 2e5 + 5;
typedef long long ll;
typedef pair<ll, ll> pll;
typedef array<ll, 3> p3;
int mod = 1e9+7;
const int maxv = 4e6 + 5;
// #define endl "\n"


void solve()
{
	ll n,k;
	cin>>n>>k;
	__int128_t sum=(1+k)*(__int128_t)k/2;//注意题目为1e10的数据范围,所以ll存不下,要么使用int128,要么对式子进行变形
	if(sum>n){
		cout<<-1<<endl;
		return ;
	}
	vector<ll> a;
	for(int i=1;i<=n/i;i++){
		if(n%i==0){
			a.push_back(i);
			if(n/i!=i) a.push_back(n/i);
		}
	}
	ll ans=-1;
	for(auto x: a){
		if(n%x==0){
			ll cnt=n/x;
			if(cnt>=sum){
				ans=max(ans,x);
			}
		}
	}
	if(ans==-1){
		cout<<ans<<endl;
		return;
	}
	else{
		ll cnt=0;
		for(int i=1;i<=k-1;i++){
			cout<<ans*i<<" ";
			cnt+=i;
		}
		ll tot=n/ans;
		cout<<(tot-cnt)*ans<<endl;
	}
}

int main()
{
    ios::sync_with_stdio(0);
	cin.tie(0);
	cout.tie(0);
	int t;
	t=1;
	// cin>>t;
	while(t--){
		solve();
	}
   	system("pause");
    return 0;
}

D. Magazine Ad

思路:二分答案

#include <bits/stdc++.h>

using namespace std;
const int N = 2e5 + 5;
typedef long long ll;
typedef pair<ll, ll> pll;
typedef array<ll, 3> p3;
int mod = 1e9+7;
const int maxv = 4e6 + 5;
// #define endl "\n"

int k;

vector<int> a;
vector<string> ss;

bool check(int x)
{
    int h=1;
    int sum=0;
    for(auto len: a){
        if(len>x) return false;
        if(sum+len>x){
            sum=len;
            h++;
        }
        else sum+=len;
    }
    return h<=k;
}

void solve()
{
    cin>>k;
    string s;
    while(cin>>s){
        ss.push_back(s);
    }
    for(int i=0;i<ss.size();i++){
        string s=ss[i];
        int sum=0;
        for(int i=0;i<s.size();i++){
            if(s[i]=='-'){
                a.push_back(sum+1);
                sum=0;
            }
            else sum++;
        }
        if(sum){
            if(i==ss.size()-1) a.push_back(sum);
            else a.push_back(sum+1);
        }
    }
    int l=0,r=1e9+5;
    int ans=0;
    while(l<=r){
        int mid=(l+r)/2;
        if(check(mid)){
            ans=mid;
            r=mid-1;
        }
        else l=mid+1;
    }
    cout<<ans<<endl;

}

int main()
{
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    int t;
    t=1;
    //cin>>t;
    while(t--){
        solve();
    }
    system("pause");
    return 0;
}

E. Roma and Poker

每天晚上,罗姆都会在他最喜欢的网站上玩在线扑克。这个网站上的扑克规则有点奇怪:一手牌总是有两个玩家,没有赌注,赢家从输家那里拿走 1 个虚拟布尔。

昨天晚上,罗姆开始玩扑克。他决定花费不超过 k 个虚拟布尔 - 如果输的比赢的多 k 个,他将立即停止游戏。此外,如果 Roma 赢的钱够他玩一晚上,即赢的钱比输的钱多 k ,他就会离开游戏。

第二天早上,罗姆发现了一张纸,上面有一个代表他结果的序列。罗马记不清楚结果了,而且序列中有些字符的写法让人无法辨认,所以罗马记不起自己是赢了 k 布尔还是输了。

Roma 写的序列是一个字符串 s ,由字符 W (Roma 赢了相应的一手牌)、L (Roma 输了)、D (平局)和 ? (未知结果)组成。罗姆希望通过将所有 ? 字符更改为 W, L 或 D 来恢复任何 valid 序列。如果满足所有这些条件,该序列就称为 valid 序列:

最终胜负数的绝对差等于 k ;
没有一手牌的绝对差等于 k 。
帮助 Roma 恢复任何这样的序列。

思路:限制条件比较多,考虑差分约束。

如果当前为W,则 d i − d i − 1 = 1 d_i-d_{i-1}=1 didi1=1
如果当前为D,则 d i − d i − 1 = 0 d_i-d_{i-1}=0 didi1=0
如果当前为L,则 d i − d i − 1 = − 1 d_i-d_{i-1}=-1 didi1=1
考虑两者之间差的绝对值不大于1,则 ∣ d i − d i − 1 ∣ ≤ 1 |d_i-d_{i-1}|\le1 didi11
考虑到第 i 位为止,其前缀和小于等于k,则 ∣ d i − d 0 ∣ ≤ k − 1 |d_i-d_{0}|\le k-1 did0k1
考虑最终差值位 k ,则 ∣ d n − d 0 ∣ = k |d_n-d_0|=k dnd0=k
根据上述进行不等式转换即可。

#include <bits/stdc++.h>

using namespace std;
const int N = 2e5 + 5;
typedef long long ll;
typedef pair<ll, ll> pll;
typedef array<ll, 3> p3;
int mod = 1e9+7;
const int maxv = 4e6 + 5;
// #define endl "\n"

vector<pll> e[N];

void add(int u,int v,int w)
{
    e[u].push_back({v,w});
}

int cnt[N];
int st[N];
ll d[N];
int n,k;
bool spfa()
{
    for(int i=0;i<=n;i++) d[i]=2e9,st[i]=cnt[i]=0;
    d[0]=0,st[0]=1;
    queue<int> q;
    q.push(0);
    while(!q.empty()){
        int t=q.front();
        q.pop();
        st[t]=0;
        for(auto [u,w]: e[t]){
            if(d[u]>d[t]+w){
                d[u]=d[t]+w;
                if(!st[u]){
                    st[u]=1;
                    q.push(u);
                    cnt[u]++;
                    if(cnt[u]>n) return false;
                }
            }
        }
    }
    return true;
}

void solve()
{
    cin>>n>>k;
    string s;
    cin>>s;
    //n=s.size();
    s=" "+s;
    for(int i=1;i<=n;i++){
        if(s[i]=='W'){
            add(i-1,i,1);
            add(i,i-1,-1);
        }
        else if(s[i]=='D'){
            add(i-1,i,0),add(i,i-1,0);
        }
        else if(s[i]=='L') add(i-1,i,-1),add(i,i-1,1);
        else add(i-1,i,1),add(i,i-1,1);
        if(i<n) add(i,0,k-1),add(0,i,k-1);
    }
    add(0,n,k),add(n,0,-k);
    if(spfa()){
        for(int i=1;i<=n;i++){
           // cout<<d[i]<<" ";
            if(d[i]-d[i-1]==1) cout<<"W";
            else if(d[i]-d[i-1]==0) cout<<"D";
            else cout<<"L";
        }
        cout<<endl;
        return;
    }
    e[n].pop_back();
    e[0].pop_back();
    add(0,n,-k),add(n,0,k);
    if(spfa()){
        for(int i=1;i<=n;i++){
           // cout<<d[i]<<" ";
            if(d[i]-d[i-1]==1) cout<<"W";
            else if(d[i]-d[i-1]==0) cout<<"D";
            else cout<<"L";
        }
        cout<<endl;
        return;
    }
    cout<<"NO"<<endl;

}

int main()
{
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    int t;
    t=1;
    //cin>>t;
    while(t--){
        solve();
    }
    system("pause");
    return 0;
}

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

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

相关文章

系列六、JVM的内存结构【栈】

一、产生背景 由于跨平台性的设计&#xff0c;Java的指令都是根据栈来设计的&#xff0c;不同平台的CPU架构不同&#xff0c;所以不能设计为基于寄存器的。 二、概述 栈也叫栈内存&#xff0c;主管Java程序的运行&#xff0c;是在线程创建时创建&#xff0c;线程销毁时销毁&…

48v变12v同步转换芯片

48v变12v同步转换芯片 以下是一篇关于48V变12V同步转换器WD5105ic的文章正文&#xff1a;48V变12V同步转换器WD5105ic是一种电源管理芯片&#xff0c;它可以将48V的直流电压转换为12V的直流电压。这款芯片具有广泛的应用范围&#xff0c;包括车载充电器件、电动车仪表器件、电…

系列二、什么是OOM?什么是StackOverflowError?有哪些方法分析?

一、什么是OOM&#xff1f; OOM是堆内存溢出&#xff0c;产生的原因是堆的空间大小是有限的&#xff0c;当堆空间的大小不足以满足创建对象所需要的内存空间时&#xff0c;就会抛出OOM的异常。 二、什么是StackOverflowError&#xff1f; StackOverflowError是栈内存溢出的意思…

C++核心编程 day09 类型转换、异常、输入输出流

C核心编程 day09 类型转换、异常、输入输出流 1. 类型转换2. 异常2.1 异常语法2.2 C标准异常库 3. 输入输出流3.1 输入输出流概念以及流类库3.2 标准输入流3.3 标准输出流3.4 文件读写 1. 类型转换 C中的类型转换有四类&#xff0c;分别是静态转换、动态转换、常量转换、重新解…

STM32 ADC介绍和应用

目录 1.ADC是什么&#xff1f; 2.ADC的性能指标 3.ADC特性 4.ADC通道 5.ADC转换顺序 6.ADC触发方式 7.ADC转化时间 8.ADC转化模式 扫描模式 单次转换/连续转换 9.ADC实验 使用ADC读取烟雾传感器的值 代码实现思路&#xff1a; 核心代码示例&#xff1a; 1.ADC是什…

算法---相等行列对

题目 给你一个下标从 0 开始、大小为 n x n 的整数矩阵 grid &#xff0c;返回满足 Ri 行和 Cj 列相等的行列对 (Ri, Cj) 的数目。 如果行和列以相同的顺序包含相同的元素&#xff08;即相等的数组&#xff09;&#xff0c;则认为二者是相等的。 示例 1&#xff1a; 输入&…

Windows10电脑没有微软商店的解决方法

在Windows10电脑中用户可以打开微软商店&#xff0c;下载自己需要的应用程序。但是&#xff0c;有用户反映自己Windows10电脑上没有微软商店&#xff0c;但是不清楚具体的解决方法&#xff0c;接下来小编给大家详细介绍关于解决Windows10电脑内微软商店不见了的方法&#xff0c…

01Urllib

1.什么是互联网爬虫&#xff1f; 如果我们把互联网比作一张大的蜘蛛网&#xff0c;那一台计算机上的数据便是蜘蛛网上的一个猎物&#xff0c;而爬虫程序就是一只小蜘蛛&#xff0c;沿着蜘蛛网抓取自己想要的数据 解释1&#xff1a;通过一个程序&#xff0c;根据Url(http://www.…

linux清理僵尸进程

当你top看到这个&#xff0c;或者按M后看到内存吃的很多&#xff0c;那你看下有没有&#x1f9df; 二选一查看是什么进程 ps aux | egrep "Z|defunct" ps -aux | awk {if($8"Z"){print $2,$11}}没用直接杀杀杀 kill -9 查到的PID号可中断下载文件 wget…

【Linux网络】工作环境救急——关于yum安装的5个花式操作

目录 1、只下载不安装&#xff0c;离线安装软件 2、自行打包创建元数据 第一步&#xff1a;先准备好nginx的软件包&#xff0c;放在一个文件夹下 第二步&#xff1a;在本地下载createrepo命令软件&#xff0c;用于创建元信息&#xff0c;这个一定是对包的上一级目录使用命令…

【整顿C盘】pycharm、chrome等软件,缓存移动

C盘爆了&#xff0c;特来找一下巨大的软件缓存&#xff0c;特此记录&#xff0c;跟随的各大教程&#xff0c;和自己的体会 一、爆炸家族JetBrains 这个适用于pycharm、idea、webstorm等等&#xff0c;只要是JetBrains家的&#xff0c;2020版本以上&#xff0c;都是一样的方法 p…

python内置模块subprocess 模块,创建和管理子进程

一、简介 subprocess 是 Python 标准库中的一个模块&#xff0c;用于创建和管理子进程。它提供了一种在 Python 程序中启动新进程、连接到它们的输入/输出/错误管道以及获取它们的返回值的方法。 使用 subprocess 模块&#xff0c;你可以在 Python 程序中执行外部命令、调用其…

Linux_/proc目录_查看处理器的信息/proc/cpuinfo

1、cat /proc/cpuinfo_查看/proc/cpuinfo文件的内容 可以看到板卡有4个处理器&#xff0c;剩下的信息emmm...... 2、BogoMIPS_反映CPU运算速率 MIPS是millions of instructions per second(百万条指令每秒)的缩写&#xff0c;其代表CPU的运算速率。 BogoMIPS是Linux大致计算…

Python开源项目GPEN——人脸重建(Face Restoration),模糊清晰、划痕修复及黑白上色的实践

无论是自己、家人或是朋友、客户的照片&#xff0c;免不了有些是黑白的、被污损的、模糊的&#xff0c;总想着修复一下。作为一个程序员 或者 程序员的家属&#xff0c;当然都有责任满足他们的需求、实现他们的想法。除了这个&#xff0c;学习了本文的成果&#xff0c;或许你还…

springcloud失物招领网站源码

开发技术&#xff1a; jdk1.8&#xff0c;mysql5.7&#xff0c;idea&#xff0c;nodejs&#xff0c;vscode springcloud springboot mybatis vue elementui 功能介绍&#xff1a; 用户端&#xff1a; 登录注册 首页显示搜索失物&#xff0c;轮播图&#xff0c;最新发布的…

OpenCV快速入门:基本操作

文章目录 1. 像素操作1.1 像素统计1.2 两个图像之间的操作1.2.1 图像加法操作1.2.3 图像加权混合 1.3 二值化1.4 LUT&#xff08;查找表&#xff09;1.4.1 查找表原理1.4.2 代码演示 2 图像变换2.1 旋转操作2.1.1 旋转的基本原理2.1.2 代码实现 2.2 缩放操作2.3 平移操作2.3.1 …

基于SSM的宠物综合服务平台的设计与实现

末尾获取源码 开发语言&#xff1a;Java Java开发工具&#xff1a;JDK1.8 后端框架&#xff1a;SSM 前端&#xff1a;Vue 数据库&#xff1a;MySQL5.7和Navicat管理工具结合 服务器&#xff1a;Tomcat8.5 开发软件&#xff1a;IDEA / Eclipse 是否Maven项目&#xff1a;是 目录…

Topaz Video AI:引领视频质量革命,让您的内容焕发新生

随着数字媒体的日益普及&#xff0c;视频质量的重要性日益凸显。无论是个人用户还是专业团队&#xff0c;都需要确保他们的视频内容具有最佳的质量。但是&#xff0c;由于各种原因&#xff0c;如设备限制、环境干扰等&#xff0c;往往导致视频质量不尽如人意。这时&#xff0c;…

【ISP图像处理】Demosaic去马赛克概念介绍以及相关方法整理

1. 基本定义 使用彩色滤光器阵列(CFA)的数码相机需要一个去马赛克程序来形成完整的RGB图像。一般的相机传感器都是采用彩色滤光片阵列(CFA)放置在光感测单元上&#xff0c;在每个像素处仅捕获三种原色成分中的一种。 去马赛克方法主要关注于复原非常规区域&#xff0c;比如边缘…

mybatis之主键返回

1.在mybatis的xml中加入 <insert id"insertUser" keyProperty"id" useGeneratedKeys"true" parameterType"com.UserAndOrder"> insert into Tuser(userName,passWord) values (#{userName},#{passWord} ) </insert&…