当前位置: 首页 > news >正文

潮阳网站制作seo站内优化培训

潮阳网站制作,seo站内优化培训,李连杰做的功夫网站,网站原创文章在哪里找2022 ICPC 济南 E. Identical Parity (扩欧) Problem - E - Codeforces 大意:给出一个 n 和一个 k , 问是否能构造一个长 n 的排列使得所有长 k 的连续子序列和的奇偶性相同。 思路:通过分析可知 , 任两个间隔 k - 1 的元素奇偶…

2022 ICPC 济南 E. Identical Parity (扩欧)

Problem - E - Codeforces

大意:给出一个 n 和一个 k , 问是否能构造一个长 n 的排列使得所有长 k 的连续子序列和的奇偶性相同。

思路:通过分析可知 , 任两个间隔 k - 1 的元素奇偶性必然相同 , 这样的话 , 问题就转化成了

( n % k )个( ⌊ n k ⌋ + 1 )和( k − n % k )个( ⌊ n k ⌋ )是否能组成( ⌊ n 2 ⌋ )和( n − ⌊ n 2 ⌋ )的问题 (n ~\% ~k ~)个(\left \lfloor \frac{n}{k} \right \rfloor +1)和(k-n~\%~k)个(\left \lfloor \frac{n}{k} \right \rfloor)是否能组成(\left \lfloor \frac{n}{2} \right \rfloor)和(n - \left \lfloor \frac{n}{2} \right \rfloor)的问题 n % k )个(kn+1)和(kn % k)个(kn)是否能组成(2n)和(n2n)的问题

很自然的就可以想到 01 背包去解决这个问题 , 但是显然 n 和 k 的范围太大了 , 无法使用 01 背包去解决这个问题。 于是转化问题 , 考虑现有范围的 x 和 y 是否能满足以下式子。

( ⌊ n k ⌋ + 1 ) ∗ x + ( ⌊ n k ⌋ ) ∗ y = ( ⌊ n 2 ⌋ ) (\left \lfloor \frac{n}{k} \right \rfloor +1)*x~+~(\left \lfloor \frac{n}{k} \right \rfloor)*y = (\left \lfloor \frac{n}{2} \right \rfloor) kn+1x + kny=2n

带入扩欧得到通解:

x = x 0 ∗ c g c d ( a , b ) + k ∗ b g c d ( a , b ) x=x_0*{c\over gcd(a,b)}+{k*b\over gcd(a,b)} x=x0gcd(a,b)c+gcd(a,b)kb

y = y 0 ∗ c g c d ( a , b ) − k ∗ a g c d ( a , b ) y=y_0*{c\over gcd(a,b)}-{k*a\over gcd(a,b)} y=y0gcd(a,b)cgcd(a,b)ka

根据已有的 x 的范围 和 y 的范围分别求出两个 k 的范围 , 判断这两个区间是否相交即可。

易错点:是否可以通过 x 的范围求出对应 k 的范围然后带入求 y 的范围 ?显然是可以的 , 但是这样求出的 y 的范围区间是不连续的 , 也就不能判交。

#include<bits/stdc++.h>
using namespace std;
#define fi first
#define se second
#define IOS std::ios::sync_with_stdio(false),cin.tie(0),cout.tie(0);
#define int long long
const int N = 2e6 + 10;
const int mod = 1e9 + 7;
typedef pair<int,int>PII;int n , t , k;int exgcd(int a , int b , int &x , int &y){if(b == 0){ x = 1; y = 0; return a;}int g = exgcd(b , a % b , y , x);y -= a / b * x;return g;
}signed main(){IOScin >> t;while(t --){cin >> n >> k;if(n % k == 0){int num = n / k , od , ev;ev = n / 2;od = n - ev;if(ev % num == 0 && od % num == 0){cout << "Yes" << "\n";}else{cout << "No" << "\n";}}else{int a = n / k , b = n / k + 1 , c = n / 2;int cntb = n % k , cnta = k - n % k;int x , y , gcds;gcds = exgcd(a , b , x , y);a /= gcds;b /= gcds;c /= gcds;int k1_max = floor((double)(cnta - x * c) / (double) b);int k1_min = ceil((double)(0 - x * c) / (double) b);int k2_max = floor((double)(y * c) / (double) a);int k2_min = ceil((double)(y * c - cntb) / (double) a);  if(k1_min > k1_max || k2_min > k2_max){cout << "No\n";}else{if(min(k2_max , k1_max) >= max(k1_min , k2_min)){cout << "Yes\n";}else{cout << "No\n";}}}}return 0;
}
//freopen("文件名.in","r",stdin);
//freopen("文件名.out","w",stdout);
http://www.yidumall.com/news/9570.html

相关文章:

  • php做网站框架设计公司排名
  • 网站开发宣传图片seo优化员
  • 开发公司预案泽成seo网站排名
  • 广东专业移动网站建设哪家好下列关于seo优化说法不正确的是
  • 搜索网站建设推广优化好用的搜索引擎
  • 需要登陆的网站如何做爬虫网络营销案例分享
  • 提供做网站费用seo的特点是什么
  • 做网站的上海市哪家技术好seo技术有哪些
  • 更新php wordpress广州seo优化效果
  • 有哪些专门做减肥内容的网站建网站怎么赚钱
  • 做全屏网站图片显示不全百度搜索排行
  • 大家都在哪些网站上做医药招商企业培训课程有哪些
  • 静海网站建设公司今日的最新消息
  • 网站建设开发人员须知西安seo高手
  • 黑龙江做网站哪家好互动营销公司
  • 企业网站建设案例分析苏州网络公司
  • 有几个网站打不开广州宣布5条优化措施
  • 网站备案去哪里办理优化网站搜索
  • 住房和城市建设部网站专业搜索引擎seo合作
  • 深圳品牌设计网站长沙网站seo收费
  • 专业微网站建设公司哪家好seo资讯
  • 网站推广怎么做 知乎北京网站seo招聘
  • 东莞阳光网官网手机版谷歌sem和seo区别
  • 潍坊百度网站建设关键词优化一般收费价格
  • 企业为什么做企业网站和推广seo牛人
  • 网站建设管理中se是什么意思如何建立一个网站
  • 天河建设网站服务优化大师win10下载
  • 专门做网站搜索优化的公司推广方案应该有哪些方面
  • 唐山自助建站直通车怎么开效果最佳
  • 什么主题和风格的网站好seo在中国