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

网站建设业务活动网上推广

网站建设业务活动,网上推广,做动态影集的网站,wordpress图片主题破解登录—专业IT笔试面试备考平台_牛客网 题目大意:有一个n个数的数组a,有n-1轮操作,每轮由每个数选择一个和它的差最大的数,如果相同就选值更大的,被最多数组选择的数字被删去,有相同的也去掉数值更大的那个…

登录—专业IT笔试面试备考平台_牛客网

题目大意:有一个n个数的数组a,有n-1轮操作,每轮由每个数选择一个和它的差最大的数,如果相同就选值更大的,被最多数组选择的数字被删去,有相同的也去掉数值更大的那个,问最后剩下的是哪一个数字

1<=n<=1e6;1<=ai<=1e9

思路:每次操作一定是删除最大数或者最小数的其中一个,所以我们可以将数组排序然后模拟操作,维护当前剩余数的区间左右端点l,r,求出当前区间长度len=r-l+1,因为右边的数肯定选最小的那个,左边的数肯定选最右边那个,所以我们看中间的那个数选择哪个,如果len是偶数,要看中间偏左的那一个,因为平票是会选数值更大那一个的,也就是最大值,然后看中间值和右边的差,如果右边的差大于等于左边,就投出右边的,r--反之l++,直到l=r,最后在原数组中找到最后剩下的数的位置即可

//#include<__msvc_all_public_headers.hpp>
#include<bits/stdc++.h>
using namespace std;
const int N = 1e6 + 5;
typedef long long ll;
int a[N];
int b[N];
int main()
{int n;cin >> n;for (int i = 1; i <= n; i++){cin >> a[i];b[i] = a[i];//保留原数组}sort(a + 1, a + n + 1);int l = 1, r = n;while (l < r){int len = r - l + 1;int pos = len / 2 + l;if (len % 2 == 0)pos--;//偶数时要选左边的if (a[r] - a[pos] >= a[pos] - a[l]){//右边差大于左边或者平票都是投出最右边的r--;}elsel++;}for (int i = 1; i <= n; i++){if (b[i] == a[l])//在原数组中找到最后剩下的数{cout << i << endl;break;}}return 0;
}

http://www.zhongyajixie.com/news/50380.html

相关文章:

  • 建筑工程公司需要什么资质优化器
  • 自己做网站卖仿货域名免费注册
  • 网站服务器设置免费个人网站模板
  • 网站开发 法律营销网站建设专家
  • 可以做海报的网站广州网络推广培训
  • 广州机械网站开发潍坊快速网站排名
  • 用sql做简单的博客网站网络广告文案范文
  • 学设计的网站推荐百度大数据查询平台
  • python做后台网站的多吗抚顺网站seo
  • 手机社交网站建设我要看今日头条
  • 郑州仿站定制模板建站孔宇seo
  • 个人网络工作室seo网站推广专员
  • 免费简历模板的网站长沙做网络推广公司的
  • 网站开发跟软件开发国际域名注册网站
  • photoshop做网站设计美食软文300字
  • 物流网站建设实例什么是网站
  • 网站在互联网营销中的作用seo营销论文
  • 湛江网站制作专业百度广告投诉电话
  • 上海预计几号全部解封厦门seo总部电话
  • 如何进行电商网站设计京东关键词优化技巧
  • c#如何做公司网站3seo
  • dw做高逼格的网站培训心得体会2000字
  • 做网站需要什么人滕州百度推广
  • 本科专业建设规划优化步骤
  • 安徽淮北做网站的公司有哪些深圳百度推广关键词推广
  • 公司做宣传网站seo查询百科
  • seo排名软件怎么做seo是什么意思电商
  • 影视网站怎么做刷网站关键词工具
  • 做优秀网站苏州网站建设
  • 深圳网站制作建设公司广州seo推广