9.11 codeforces

news/2024/9/17 18:29:21/文章来源:https://www.cnblogs.com/dontian/p/18407509

A. Make a Square
n的范围不超过2*10的9次方,那么最大的i是44722,从大到小开始,如果在n中找到i的平方,那么说明存在这个数的平方break即可

#include <bits/stdc++.h>#define  int long long
using namespace std;
int v[1008611];
int prefix[1008611];
int32_t main( )
{ios::sync_with_stdio(false);cin.tie(nullptr);string s1;cin>>s1;int aa=0;for(int i=44722;i>=1;i--){int pd=1;string s= to_string(i*i);if(s.length()<=s1.length()) {int j = 0;for (auto c: s1) {if (c == s[j]) {j++;}}if (j == s.length()) {cout << s1.length() - s.length();aa = 1;break;}}}if(aa==0)cout<<-1;return 0;}

A. Load Balancing
我们要让整个数组的最大最小值差不超过1,我们可以先找平均值,然后把多余平均值的数逐一分配给前面的数

#include <bits/stdc++.h>#define int long longusing namespace std;int v[1008611];int32_t main(){ios::sync_with_stdio(false);cin.tie(nullptr);int n;cin>>n;int sum=0;for(int i=1;i<=n;i++){int a;cin>>a;v[i]=a;sum+=a;}int s=sum;s/=n;//注意如果不能整除说明最后分配出来的会有多出来的情况if(sum%n)s++;int p=0;int q=0;int ans=0;int pd=0;for (int i = 1; i <=n; ++i) {if(v[i]<s-1)p+=s-1-v[i];if(v[i]>s)q+=v[i]-s;}// cout<<q<<p<<'\n';cout<<max(q,p);
}

C. Match Points
有点贪心加双指针的意思
我们要想使得点数最多,那么n/2就是最多的点对数,我们先对数组进行排列,让一个指针l从n开始,一个r从n/2开始
如果符合条件那么l--,整个过程r一直减r--;


#include <bits/stdc++.h>#define  int long longusing namespace std;int v[1008611];
int prefix[1008611];int32_t main( )
{ios::sync_with_stdio(false);cin.tie(nullptr);int n,m;cin>>n>>m;for (int i = 1; i <=n ; ++i) {cin>>v[i];}sort(v+1,v+1+n);int ans=0;int l=n,r=n/2;while(r>=1){if(abs(v[l]-v[r])>=m) {ans++;l--;}r--;}cout<<ans;return 0;}

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

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

相关文章

Pyqt5 实现多标签页面

实现功能代码实现 import sysfrom PyQt5.QtWidgets import QApplication, QMainWindow, QTabWidget, QVBoxLayout, QPushButton, QWidget, QLabel, \QDesktopWidgetclass MainWindow(QMainWindow):def __init__(self):super().__init__()self.ini_ui()def ini_ui(self):self.se…

gitee【下载文件】

1.配置公钥(如果是新设备) ssh-keygen -t ed25519 -C "Gitee SSH Key"输入这行命令,按3次回车,演示如下: 生成的公钥就在红框文件夹下复制该字符串,进入gitee的设置中,找到公钥粘贴该字符串配置完后可用该命令测试 ssh -T [git@gitee.com](mailto:git@gitee.c…

gitee【上传文件】

1.配置公钥 ssh-keygen -t ed25519 -C "Gitee SSH Key"输入这行命令,按3次回车,演示如下: 生成的公钥就在红框文件夹下复制该字符串,进入gitee的设置中,找到公钥粘贴该字符串配置完后可用该命令测试 ssh -T [git@gitee.com](mailto:git@gitee.com)2.新建仓库并配…

【技术积累】腾讯/阿里云对象存储上传+删除

腾讯/阿里云对象存储上传+删除创建储存桶 (后面会用到 储存库名称、访问域名、以及region) region(地域和访问域名)的查询参考: https://cloud.tencent.com/document/product/436/6224 https://www.aliyun.com/product/oss常用的阿里云、腾讯云2.创建Api密钥 (后面会用到…

虚拟机安装 gho系统

1.新建 虚拟机2.使用 _优先安装WePE_64_V2.3.exe 制作一个可启动iso3.gho文件 用UltraISO 制作为一个iso文件4.虚拟机用 前面制作的iso文件启动后 分区 ,然后启动 gho工具,再加载iso文件5.此时可以进行克隆还原了

Qt使用绿色pdf阅读器打开文件

1.下载SumatraPDF 2.设置 3.代码void MainWindow::on_pushButton_clicked() {QProcess *process = new QProcess();QString filePath = "C:\\Users\\jude\\Desktop\\su\\11.pdf";QString sumatraPath = "C:\\Users\\jude\\Desktop\\su\\SumatraPDF-3.5.2-64.exe…

基于tf-idf的论文查重

基于tf-idf的论文查重 github地址:https://github.com/gomevie/gomevie/tree/main这个作业属于哪个课程 广工计院计科34班软工这个作业要求在哪里 作业要求 这个作业的目标 设计并实现一个论文查重算法,通过比较原文和抄袭版论文文件,计算并输出重复率。PSP表格PSP2.1 Pers…

Java SE 语法学习

JavaSE 语法 java数据类型基本数据类型整数类型byte 占1个字节,范围:-128-127 short占2个字节,范围:-32768-32767 int占4个字节,范围:-2147483648-2147483647 long占8个字节,范围:-9223372036854775808-9223372036854775807浮点数类型double占8个字节 float占4个字节字…

今天学习和总结

学习了简单的算法知识排序中的快速排序,利用分治的思想来实现快速排序,对于前后大小有问题的进行swap的交换位置,这是基本的模版和源码 include using namespace std; define N 1000100 int A[N]; void quick_sort(int a,int b){ if(a>=b)return ; int i=a-1,j=b+1,x=A[a+b&…

代码整洁之道--读书笔记(7)

代码整洁之道简介: 本书是编程大师“Bob 大叔”40余年编程生涯的心得体会的总结,讲解要成为真正专业的程序员需要具备什么样的态度,需要遵循什么样的原则,需要采取什么样的行动。作者以自己以及身边的同事走过的弯路、犯过的错误为例,意在为后来者引路,助其职业生涯迈上更…

痞子衡嵌入式:在MDK开发环境下自定义安装与切换不同编译器版本的方法

大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家分享的是在MDK开发环境下自定义安装与切换不同编译器版本的方法。Keil MDK 想必是嵌入式开发者最熟悉的工具之一了,自 2005 年 Arm 公司收购 Keil 公司之后,MDK 就走上了发展快车道,从 v2.50a 一路狂奔到现在最新的…