Codeforces Round 900 (Div. 3)(A-F)

比赛链接  :

Dashboard - Codeforces Round 900 (Div. 3) - Codeforces

A. How Much Does Daytona Cost?

题面 : 

思路 :

在序列中只要找到k,就返回true ;

代码 : 

#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
#define endl '\n'using namespace std;
typedef long long LL;
const int N = 2e5+10;inline void solve(){int n , k ; cin >> n >> k ;bool tag = false;for(int i=0;i<n;i++){int x ; cin >> x ;if(x==k) tag = true;}if(tag) cout << "Yes" << endl;else cout << "No" << endl;return ;
}int main()
{IOSint _ = 1;cin >> _;while(_ --) solve();return 0;
}

B. Aleksa and Stack

题面 : 

思路 :

在这道题中,只要满足任意两个相邻数的和,不能够不是3的倍数,且数组单调递增,那么便可以构造出这样一个序列,每两个相邻数中第一个数 mod 3 = 0,另一个数mod 3 = 1 ,然后递增的话,就可以使a1 = 3 *1 , a2= a1 + 1,a3 = 3 * 2,a4 = a3 + 1,即可满足题目条件;

代码

#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
#define endl '\n'using namespace std;
typedef long long LL;
int gcd(int a,int b){ return b==0 ? a : gcd(b,a%b); }
int lcm(int a,int b){ if(a==0||b==0) return 0; return (a*b)/gcd(a,b); }
bool is_prime(int x){if(x<2) return false;
for(int i=2;i<=x/i;i++) if(x%i==0) return false; return true;}
//numbers.erase(std::unique(numbers.begin(), numbers.end()), numbers.end()); // 去重操作
const int N = 2e5+10;// 任意两个数的和不是3的倍数 // 0, 1, 2
// 3 , 4 , 6, 7 inline void solve(){int n ; cin >> n ;int x = 3;while(n>1){cout << x << " " << x + 1 << " ";x += 3;n -= 2;}if(n) cout << x ;cout << endl ;return ;}int main()
{IOSint _ = 1;cin >> _;while(_ --) solve();return 0;
}

 C. Vasilije in Cacak

题面 : 

思路 : 

对于从  [1 ,n ]  中 选k个数 的 和为x;

假如 n = 2 (并且假设k = 2,下面一样):

         1,2 --> 1, 2, 3
n = 3 :

        1, 2 ,3 : 1,2,3,4,5,6 选两个 : 3-5 
n = 4 :

        1,2,3,4 : 3-7 :  

那么我们就可以发现一个规律 : 在[1,n]中取k个数和的范围是[最小的k个数相加,最大的k个数相加];

为了计算的方便,我们可以使用等差数列求和 : s = n*a1+(n-1)*n*d/2  ;

代码 : 

#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
#define endl '\n'using namespace std;
typedef long long LL;LL n , k , x ;// [1,n] 中 选k个数 的 和为x;// 1,2 --> 1, 2, 3
//1, 2 ,3 : 1,2,3,4,5,6 选两个 : 3-5 
// 1,2,3,4 : 3-7 :  // 等差数列求和 : s = n*a1+(n-1)*n*d/2 inline void solve(){cin >> n >> k >> x;LL l = (1+k)*k/2 , r = (n+n-k+1)*k/2;if(x>=l && x<=r) cout << "Yes" << endl;else cout << "No" << endl;return ;
}int main()
{IOSint _ = 1;cin >> _;while(_ --) solve();return 0;
}

D. Reverse Madness

题面

思路 : 

l和r都是单调递增的,且对于每一段区间都是不相交的,所有可以很快找到x对应的li和ri来满足li<=x && x<=ri ;

找到之后就是进行区间的反转,对于每个区间假设li = 2,ri =6,如果x = 4,则a=b=4,如果x=3,则a=3,b=5;那么说明是关于终点对称的,那么就可以使用前缀和算法,来对每个点进行反转次数的统计,如果统计次数为偶那就不用反转了,为奇,则要反转,具体请看代码;

代码

#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
#define endl '\n'using namespace std;
typedef long long LL;
const int N = 2e5+10;inline void solve(){int n,k;cin >> n >> k ;string s ; cin >> s ;s = ' ' + s ;vector<int> l(k+1) , r (k+1) ;for(int i=1;i<=k;i++) cin >> l[i] ;for(int i=1;i<=k;i++) cin >> r[i] ;int q ; cin >> q ;vector<int> x(q+1) ;for(int i=1;i<=q;i++) cin >> x[i] ;vector<pair<int,int>> sum(n+3) ;for(int i=1;i<=q;i++){int pos = lower_bound(r.begin()+1,r.end(),x[i]) - r.begin();int a = min(x[i] , r[pos]+l[pos]-x[i]);int b = max(x[i],r[pos]+l[pos]-x[i]);sum[a].first++ ; sum[b+1].first--;sum[a].second = b ; sum[b].second = a ;}for(int i=1;i<n;i++){sum[i].first += sum[i-1].first ;}int start = -1 , end = -1 ;for(int i=1;i<=n;i++){if(sum[i].first % 2 == 1){start = i ;int end = sum[i].second ;while(start <= end){while(start<=end && sum[start].first % 2 == 1){swap(s[start],s[end]);start ++;end--;}while(start <= end && sum[start].first % 2 == 0){start ++;end -- ;}}i = sum[i].second ;}}for(int i=1;i<=n;i++) cout << s[i] ;cout << endl; 
}int main()
{IOSint _ = 1;cin >> _;while(_ --) solve();return 0;
}

E. Iva & Pav

题面 :

思路 : 

// f(l,r)=al & al+1 &…& ar
// 给定一个 l , k ,求最大的r,满足f(l , r) >= k ;
// 定l,则f随着r单调递减 
// & : 按位与 

按位与的特点是,对于某一位,[l,r]上的所有数的该位上为1,结果才为1,那么我们可以采用前缀和的思想,用bit[i][j]来存[1,i]上第j位上为1的个数,具体实现请看代码,再获得bit数组之后,因为在l确定之后,f(l,r)随着r的增大具有单调递减的性质,所有可以使用二分来进行操作;

具体实现请看代码 ;

代码 : 

// f(l,r)=al & al+1 &…& ar
// 给定一个 l , k ,求最大的r,满足f(l , r) >= k ;
// 定l,则f随着r单调递减 
// & : 按位与 
#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
#define endl '\n'using namespace std;
typedef long long LL;
const int N = 2e5 + 10 ;inline void solve(){int n ; cin >> n ;vector<array<int,32>> bit(n+1);for(int i=1;i<=n;i++){int x ; cin >> x ;for(int j = 0;j<32;j++){bit[i][j] = 0 ;bit[i][j] += x % 2 ;x /= 2 ;bit[i][j] += bit[i-1][j] ; // 进行前缀和操作,统计i前面j位上为1的个数 }	} auto check = [&](int l,int r ,int c){vector<int> b(32) ;for(int i=0;i<32;i++){b[i] = bit[r][i] - bit[l-1][i] ;}int ans = 0 ;for(int i=0;i<32;i++){if(b[i]==r-l+1) ans += pow(2,i);}return ans >= c ; };int q ; cin >> q ;while(q--){int l , k ; cin >> l >> k ;int L = l, R = n;int ans = -1 ;while(L<=R){int mid = (L+R)>>1 ;if(check(l,mid,k)){ans = mid ;L = mid + 1; }else{R = mid - 1 ;}}cout << ans << " " ;}cout << endl ;
}int main()
{IOSint _ = 1;cin >> _;while(_ --) solve();return 0;
}

F. Vasilije Loves Number Theory

题面 : 

思路 : 

  •  1 : n *= x,然后问是否存在一个a使得gcd(n,a)=1并且n*a的约数个数等于n,
  • gcd(n,a)=1 --> n,a互质
  • 由于n,a互质,那么 d(n)*d(a)=d(n*a),那么就是要d(a) = n / d(n),所以n % d(n)一定要等于零 

然后就可以通过唯一分解定理来解;

具体实现请看代码 :

代码

#include<bits/stdc++.h>
#define IOS ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
#define endl '\n'using namespace std;
typedef long long LL;
const int N = 2e5+10;// 1 : n *= x,然后问是否存在一个a使得gcd(n,a)=1并且n*a的约数个数等于n,
// gcd(n,a)=1 --> n,a互质
// --> d(n)*d(a)=d(n*a),那么就是要d(a) = n / d(n),所以n % d(n)一定要等于零 inline void solve(){int n,q;cin>>n>>q;int cnt = 1 ; // 记录因数的数量 map<int,int> doc ;// 质因数分解 : // num = b1^c1 + b2 ^c2 + .... + bn^cn ; for(int i=2;i*i<=n;i++){// i相当于上面的b,c相当于上面的c ; if(n%i==0){int c =  0 ;while(n%i==0) n/=i,c++;doc[i] = c ;cnt *= (c+1);}}if(n>1) doc[n] = 1 , cnt *= 2 ; // 最后剩下的n本身也是一个质因数 int now = cnt;auto doc2 = doc ;while(q--){int op ; cin >> op ;if(op == 2){now = cnt  ;doc2 = doc ;}else{int x ; cin >> x ;for(int i=2;i*i<=x;i++){if(x%i==0){int c =  0 ;while(x%i==0) x/=i,c++;now /= (doc2[i]+1);doc2[i] += c; now *= (doc2[i]+1);}}if(x>1){now /= (doc2[x]+1);doc2[x]+=1;now *= (doc2[x]+1);}int t = now  ;for(auto it:doc2){int x = it.first ;int y = it.second ;while(y>0 && t % x== 0){t /= x ;y -- ;}}cout << (t==1?"YES":"NO")<<endl; }}
}int main()
{IOSint _ = 1;cin >> _;while(_ --) solve();return 0;
}

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

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

相关文章

客户端和驱动程序

今天我们来聊聊数据库领域中经常出现的两个术语&#xff1a;客户端和驱动程序。 客户端和驱动程序 客户端&#xff1a; 通常是指使用数据库服务的应用程序或工具。这可能是一个图形用户界面(GUI)工具、命令行工具、Web应用程序或其他形式的应用程序。客户端负责发起数据库请…

spring 之 事务

1、JdbcTemplate Spring 框架对 JDBC 进行封装&#xff0c;使用 JdbcTemplate 方便实现对数据库操作 1.1 准备工作 ①搭建子模块 搭建子模块&#xff1a;spring-jdbc-tx ②加入依赖 <dependencies><!--spring jdbc Spring 持久化层支持jar包--><dependency&…

基于SpringBoot的在线互动学习网站

文章目录 项目介绍主要功能截图:部分代码展示设计总结项目获取方式🍅 作者主页:超级无敌暴龙战士塔塔开 🍅 简介:Java领域优质创作者🏆、 简历模板、学习资料、面试题库【关注我,都给你】 🍅文末获取源码联系🍅 项目介绍 基于SpringBoot的在线互动学习网站,java…

工程类标书制作攻略

工程类标书是工程项目中非常重要的一环&#xff0c;它不仅反映了投标者的技术实力和经验&#xff0c;更是决定项目归属的关键因素。那么&#xff0c;如何制作一份高质量的工程类标书呢&#xff1f; 一、明确招标要求 在制作标书前&#xff0c;首先要仔细阅读招标文件&#xf…

性能优化(CPU优化技术)-ARM Neon详细介绍

本文主要介绍ARM Neon技术&#xff0c;包括SIMD技术、SIMT、ARM Neon的指令、寄存器、意图为读者提供对ARM Neon的一个整体理解。 &#x1f3ac;个人简介&#xff1a;一个全栈工程师的升级之路&#xff01; &#x1f4cb;个人专栏&#xff1a;高性能&#xff08;HPC&#xff09…

2024年总结的前端学习路线分享(学习导读)

勤学如春起之苗&#xff0c;不见其增&#xff0c;日有所长 。辍学如磨刀之石&#xff0c;不见其损&#xff0c;日有所亏。 在写上一篇 2023年前端学习路线 的时候&#xff0c;时间还在2023年初停留&#xff0c;而如今不知不觉时间已经悄然来到了2024年&#xff0c;回顾往昔岁月…

三、Mysql安全性操作[用户创建、权限分配]

一、用户 1.创建用户 CREATE USER test1localhost identified BY test1;2.删除用户 DROP USER test2localhost;二、权限分配 1.查询用户权限 SHOW GRANTS FOR test1localhost;2.分配权限 # 分配用户所有权限在for_end_test库的test1表 GRANT ALL PRIVILEGES ON for_end_t…

Pycharm引用其他文件夹的py

Pycharm引用其他文件夹的py 方式1&#xff1a;包名设置为Sources ROOT 起包名的时候&#xff0c;需要在该文件夹上&#xff1a;右键 --> Mark Directory as --> Sources ROOT 标记目录为源码目录&#xff0c;就可以了。 再引用就可以了 import common from aoeweb impo…

OCP NVME SSD规范解读-3.NVMe管理命令-part2

NVMe-AD-8&#xff1a;在某些情况下&#xff08;如Sanitize命令、Format NVM命令或TCG Revert方法后数据被清除&#xff09;&#xff0c;设备应允许读取已清除的LBAs而不产生错误&#xff0c;并在最后一次清除完成后&#xff0c;对未写入LBAs的读取返回所有零值给主机 NVMe-AD…

面试记录(被问倒的)

快排&#xff0c;设计模式&#xff08;观察者模式 mvc模式 单例模式&#xff09;及其优势&#xff0c;工作遇到的困难&#xff0c;解决过的问题&#xff0c;渲染管线&#xff0c;ui合批&#xff08;动静分离&#xff09;&#xff0c;比较复杂的编辑器扩展&#xff0c;算法&…

鸿蒙开发之android对比开发《基础知识》

基于华为鸿蒙未来可能不再兼容android应用&#xff0c;推出鸿蒙开发系列文档&#xff0c;帮助android开发人员快速上手鸿蒙应用开发。 1. 鸿蒙使用什么基础语言开发&#xff1f; ArkTS是鸿蒙生态的应用开发语言。它在保持TypeScript&#xff08;简称TS&#xff09;基本语法风…

二叉树题目:根到叶路径上的不足结点

文章目录 题目标题和出处难度题目描述要求示例数据范围 解法思路和算法代码复杂度分析 题目 标题和出处 标题&#xff1a;根到叶路径上的不足结点 出处&#xff1a;1080. 根到叶路径上的不足结点 难度 6 级 题目描述 要求 给定二叉树的根结点 root \texttt{root} root…

LeetCode——链表

链表 链表类型&#xff1a;单链表&#xff08;只有next指针&#xff09;、双链表&#xff08;pre指针和next指针&#xff09;、循环链表&#xff08;尾节点指向头节点&#xff09; 增、删、改、遍历、翻转、交换 1.设计链表707中等 class LinkedNode {int val;LinkedNode n…

基于SpringBoot的精简博客系统

文章目录 项目介绍主要功能截图:部分代码展示设计总结项目获取方式🍅 作者主页:超级无敌暴龙战士塔塔开 🍅 简介:Java领域优质创作者🏆、 简历模板、学习资料、面试题库【关注我,都给你】 🍅文末获取源码联系🍅 项目介绍 基于SpringBoot的精简博客系统,java项目…

关键字:throw关键字

在 Java 中&#xff0c;throw关键字用于抛出异常。当程序执行过程中发生意外情况&#xff0c;如错误的输入、资源不足、错误的逻辑等&#xff0c;导致程序无法正常执行下去时&#xff0c;可以使用throw关键字抛出异常。 以下是使用throw关键字的一些示例&#xff1a; 抛出异常…

MySQL 四种插入命令及其特点与锁机制

目录 1. INSERT INTO 2. INSERT IGNORE INTO 3. INSERT INTO ... ON DUPLICATE KEY UPDATE 4. REPLACE INTO 总结 MySQL提供了多种数据插入方式&#xff0c;每种方式在处理唯一键冲突时的行为不同&#xff0c;同时也涉及不同的锁机制。 1. INSERT INTO INSERT INTO是标准…

JaveScript 的 newFunction

1、new Function的基础概念 new Function() 是 JavaScript 中的一个构造函数&#xff0c;它可以实例化一个新的函数对象并返回。该函数对象可以使用传递给 new Function() 的字符串参数作为函数体&#xff0c;并使用其他传递给它的参数作为函数参数&#xff0c;从而动态创建一…

42 个通过示例解释所有 JavaScript 数组方法

今天&#xff0c;就让我们一起来看看这 42 个数组方法。 1. at 获取特定索引处的元素。 负索引表示从末尾开始计数&#xff08;例如&#xff1a;-1 是最后一个元素&#xff09;。 const names ["Jhon", "Bob", "Alice", "Joe"]; c…

服装店收银系统不只是收银 还需要线上商城和线上批发

一个综合性的服装店收银系统可以结合线上商城和线上批发功能&#xff0c;提供以下特点和优势&#xff1a; 线上商城&#xff1a;将服装店的商品信息同步到线上商城平台&#xff0c;让顾客可以通过网站或移动应用程序浏览和购买商品。线上商城可以实现在线支付、订单跟踪、售后服…

MySQL数据库索引优化

一、引言 1. 索引的重要性 MySQL数据库索引的重要性主要体现在&#xff0c;一是查询速度优化&#xff0c;索引可以极大地提高查询速度。对于没有索引的表&#xff0c;MySQL必须进行全部扫描来找到所需的行&#xff0c;如果表中数据量很大&#xff0c;那么通常很慢。通过适当的…