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

外国网站上做Task吉林seo推广

外国网站上做Task,吉林seo推广,计算机应用技术好就业吗,夜夜做新郎网站在线视频题面链接:Dashboard - Codeforces Round 1024 (Div. 2) - Codeforces A. Dinner Time 思路 一共n个数被分成n/p个区间,每个区间内的和是q,如果还有除构成区间外剩余的数那么就一定能构造,如果没有剩余就看所有区间的和是否等于…

题面链接:Dashboard - Codeforces Round 1024 (Div. 2) - Codeforces

A. Dinner Time

思路

一共n个数被分成n/p个区间,每个区间内的和是q,如果还有除构成区间外剩余的数那么就一定能构造,如果没有剩余就看所有区间的和是否等于m

代码

void solve(){int n,m,p,q;cin>>n>>m>>p>>q;int t=n/p;int res=n%p;if(res==0){if(t*q!=m){cout<<"No\n";}else{cout<<"Yes\n";}}else{cout<<"Yes\n";}
}

B. The Picky Cat

思路

我们统计绝对值大于x的数,如果大于的数过半就可以,我们可以将绝对值大于x的数取负那么原本比x大的数就会比x小

代码

void solve(){int n;cin>>n;vector<int> a(n+10);int cnt=0;  //记录绝对值大于a[1]的数量for(int i=1;i<=n;i++){cin>>a[i];}int x=abs(a[1]);for(int i=1;i<=n;i++){if(abs(a[i])>=x) cnt++;}if(cnt>=(n+1)/2){cout<<"Yes\n";}else{cout<<"No\n";}
}

C. Mex in the Grid

思路

这题得贪心地构造,我们要子网格地mex尽可能大,我们就要求对于每个网格尽可能的包含0 1 2...

我们很容易看出我们要把0放在网格的中间,之后填数的时候我们以0为起点螺旋的构造

这样就可以贪心的保证子网格mex的和最大

代码

void solve() {int n;cin >> n;vector<vector<int>> g(n, vector<int>(n, -1));int dir[4][2] = {{0,1}, {1,0}, {0,-1}, {-1,0}};int x = n/2, y = n/2;if (n % 2 == 0) { x--; y--; }int num = 0;g[x][y] = num++;int d = 0;int st = 1;bool f = false;while (num < n * n) {for (int k = 0; k < 2; ++k) {for (int i = 0; i < st; i++) {x += dir[d][0];y += dir[d][1];if (x < 0 || x >= n || y < 0 || y >= n) continue;if (g[x][y] == -1) {g[x][y] = num++;}}d = (d + 1) % 4;}st++;}for (int i = 0; i < n; i++) {for (int j = 0; j < n; j++) {cout << g[i][j] << " ";}cout << "\n";}
}

D. Quartet Swapping

思路

关于此题我们观察出奇数和偶数要分成两组,我们在进行操作的时候偶数组和奇数组是不会相互交换的,也就是在最终答案统计的时候每个位置的数奇偶性是不会改变的

假设现在有一个数组,分为奇偶

1 2 3 4 5 6 7 8

现在我们将5移动到1的位置我们可以先后交换 先选择i=2 : 5->3  i=1 : 5->1

那么数组就会变为 5 2 1 4 3 6 7 8,这时候我们发现我们将5前移了两位,而偶数组的数并未发生改变,但是考虑我们如果只前移一位的时候我们便会交换偶数组的两个数,那么我们怎么处理才能够使得偶数组的数未发生改变,我们只需要将移动后的最后两个数交换即可

那么我们先假设最后的两个数没有交换贪心地移动偶数组和奇数组的数,最后在根据奇数组和偶数组最后有没有交换更新答案即可,那么到底移动了多少次呢?

我们回到问题的要求,需要尽可能的将小数排序,我们可以想到每次将数组小的数放到前面即可,那么就能够想到统计以下逆序对的个数,即移动次数

我们可以用BIT来统计一下偶数组和奇数组的逆序对的个数,如果奇偶性相同的话就不用交换最后的数了,如过不同我们就交换一下ans[n]与ans[n-2]

代码

#include<bits/stdc++.h>
using namespace std;#define vcoistnt ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL); 
#define int long long
#define vi vector<int>
#define vb vector<bool>
typedef pair<int,int> pll;const int N=2e5+10;
const int inf=1e18;
const int mod=998244353;#define lowbit(x) ((x)&-(x))
struct BIT{int n;vector<int> tree;void init(int x){n=x;tree.resize(x+10);}void update(int x,int d){for(int i=x;i<=n;i+=lowbit(i)){tree[i]+=d;}}int sum(int x){int ans=0;for(int i=x;i>0;i-=lowbit(i)){ans=ans+tree[i];}return ans;}
};void solve() {int n;cin>>n;vector<int> a(n+10);for(int i=1;i<=n;i++) cin>>a[i];vector<int> x,y;for(int i=1;i<=n;i++){if(i%2) x.push_back(a[i]);else y.push_back(a[i]);}//统计逆序对的数量BIT btx;btx.init(n);int sx=0;for(int i=x.size()-1;i>=0;i--){sx+=btx.sum(x[i]);btx.update(x[i],1);}BIT bty;bty.init(n);int sy=0;for(int i=y.size()-1;i>=0;i--){sx+=bty.sum(y[i]);bty.update(y[i],1);}sort(x.begin(),x.end());sort(y.begin(),y.end());vi ans(1);for(int i=1;i<=n;i++){if(i%2) ans.push_back(x[i/2]);else ans.push_back(y[(i/2)-1]);}if((sx%2)!=(sy%2)) swap(ans[n],ans[n-2]);for(int i=1;i<=n;i++){cout<<ans[i]<<" ";}cout<<"\n";}
signed main() {vcoistntcout<<fixed<<setprecision(2);int _=1;cin>>_;while(_--) solve();return 0;
}

http://www.dtcms.com/wzjs/83441.html

相关文章:

  • 网上做兼职老师的正规网站网站营销网
  • 广州天拓做网站吗企业网站大全
  • 网站科技感页面设计有哪些网页设计公司
  • 招聘网站制作公司百度极速版app下载安装挣钱
  • 自己制作一个网站需要什么软件文职培训机构前十名
  • 浦江县住房和城乡建设局网站在线工具网站
  • ps做网站字号大小win10优化软件
  • gta5买办公室 网站正在建设网络营销案例分析ppt
  • 义乌建设公司网站潍坊快速网站排名
  • 朝阳做网站的公司南宁百度首页优化
  • 怎么自己创建网站或者app外贸网站有哪些平台
  • 酷 网站模板上热门最火标题
  • 做网站空发帖推广
  • 什么网站可以接单做海报温州seo教程
  • 开发者选项开启好还是关闭好seo公司怎么推广宣传
  • 民治网站建设媒体135网站
  • 安微网站建设google在线代理
  • 漯河市住房和城乡建设委员会网站网络营销的推广方法有哪些
  • 河北沧州疫情最新数据上海seo公司排名榜
  • 工程建设比选公告固价方式网站哈尔滨网站优化
  • 苏州网站制作专业如何创建网站的快捷方式
  • 上海城乡建设和管理委员会网站好口碑关键词优化地址
  • 云相册网站怎么做的厦门seo代运营
  • 南宁有做网站的公司吗win7优化设置
  • 1简述网站建设流程图西安网站建设哪家好
  • 宜昌网站建设开发团队网站 软件
  • 网站全局变量seo文章推广
  • 360网站做推广深圳网络推广哪家比较好
  • 公司网站建设介绍烟台seo关键词排名
  • 本地做网站贵班级优化大师头像