Codeforces Round #510 (Div. 2)(C)
https://www.cnblogs.com/violet-acmer/p/9682082.html
题意:
给你n个数,定义有两种操作
① 1 i j : (i != j) 将a[i]从数列中移除,且a[j] <- a[i]*a[j]
② 2 i : 将a[i]从数列中移除,此操作最多使用一次
注意:将数移除后剩余数的编号并未改变,依旧为初始时的输入顺序
在经过n-1次操作后使剩余的数最大
题解:
使用操作②的情况:
(1) : 数列中含有0
(2) : 负数个数为奇数个
n-1个操作的最终结果为负数个数为偶数个,数列中没有0元素(当然除去全是0元素这一情况)
踩坑:
如果此数列中有负数为奇数个,且含有0元素
处理方法:
(1)先将所有0元素通过操作①使其个数变为一个;
(2)在通过操作①用最大的负数乘以0,去除一个负数两两相乘后对结果贡献最小的负数,使负数个数为偶数个;
(3)通过②操作去除0元素
AC代码:
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
const int maxn=2e5+; int n;
int a[maxn];
int neg,zero,pos;
int pos0[maxn];
int posNeg;//the position of the max negative number
bool vis[maxn]; void Reader()
{
scanf("%d",&n);
neg=zero=pos=;
posNeg=;
memset(vis,false,sizeof vis);
for(int i=;i <= n;++i)
{
scanf("%d",a+i);
if(a[i] > )
pos++;
else if(a[i] < )
{
neg++;
posNeg=(posNeg == || a[i] > a[posNeg] ? i:posNeg);
}
else
{
zero++;
pos0[zero]=i;
}
}
}
void Process()
{
int ope=;//操作数
if(zero != )//跳出此if语句后 zero == 0 || zero == 1
{
while(zero != )
{
printf("1 %d %d\n",pos0[zero],pos0[zero-]);
vis[pos0[zero]]=true;
zero--;
ope++;
}
}
if(ope == n-)
return ;
if(neg&)//如果负数个数为奇数个,通过去除一个值最大的奇数或乘以0来使奇数个数变为偶数
{
if(zero == )//如果存在0,则让值最大的负数乘以0
{
printf("1 %d %d\n",posNeg,pos0[]);//posNeg与pos0[1]顺序不可颠倒
ope++;
neg--;
if(ope < n-)
{
printf("2 %d\n",pos0[]);
vis[pos0[]]=true;
ope++;
}
}
if(ope == n-)
return ;
if(neg&)//如果 zero == 0,则需要通过删除值最大的负数来使负数个数变为偶数
{
printf("2 %d\n",posNeg);
neg--;
ope++;
}
vis[posNeg]=true;
}
else if(zero == && ope < n-)
{
printf("2 %d\n",pos0[]);
vis[pos0[]]=true;
ope++;
}
if(ope == n-)
return ; int num[maxn];
int index=;
for(int i=;i <= n;++i)
if(vis[i] != true)
num[++index]=i;
for(int i=;i < index;++i)
printf("1 %d %d\n",num[i],num[i+]);
}
int main()
{
Reader();
Process();
}
Codeforces Round #510 (Div. 2)(C)的更多相关文章
- Codeforces Round #510 (Div. 2)
Codeforces Round #510 (Div. 2) https://codeforces.com/contest/1042 A 二分 #include<iostream> usi ...
- Codeforces Round #510 (Div. 2) D. Petya and Array(离散化+反向树状数组)
http://codeforces.com/contest/1042/problem/D 题意 给一个数组n个元素,求有多少个连续的子序列的和<t (1<=n<=200000,abs ...
- Codeforces Round #510 (Div. 2) B. Vitamins
B. Vitamins 题目链接:https://codeforces.com/contest/1042/problem/B 题意: 给出几种药,没种可能包含一种或多种(最多三种)维生素,现在问要吃到 ...
- Codeforces Round #510 (Div. 2) D. Petya and Array(树状数组)
D. Petya and Array 题目链接:https://codeforces.com/contest/1042/problem/D 题意: 给出n个数,问一共有多少个区间,满足区间和小于t. ...
- Codeforces Round #510 (Div. 2)(B)
传送门:Problem B https://www.cnblogs.com/violet-acmer/p/9682082.html 题意: 如果可以通过喝果汁将维生素A,B,C全部摄取,求最小花费,如 ...
- Codeforces Round #510 (Div. 2)(A)
传送门:Problem A https://www.cnblogs.com/violet-acmer/p/9682082.html 题意: 公园里有n个沙滩,a[i]表示第i个沙滩初始人数,现有m个人 ...
- codeforces 1042d//Petya and Array// Codeforces Round #510 (Div. 2)
题意:给出一个数组,求其中和小于t的区间数. 先计算前缀和数组sum[i].对当前的sum[i],查询树状数组中有几个比(sum[i]-t)大的数,那么用sum[i]减它就是一个合法区间.再将当前的s ...
- codeforces 1042c// Array Product// Codeforces Round #510(Div. 2)
题意:给出一个数组,2种操作:.1:x*y然后x消失,2:除掉x(2操作最多只能进行一次).问最大的结果的一种操作方式.逻辑题,看能不能想全面. 1先数好0,正,负的数量,zero,pos,neg.如 ...
- Codeforces Round #510 Div. 2 Virtual Participate记
这场打的顺手到不敢相信.如果不是vp的话估计肯定打不到这个成绩. A:最大显然,最小的话每次暴力给最小的+1. #include<iostream> #include<cstdio& ...
随机推荐
- HTTP协议基础与web服务的重定向,跳转以及请求转发
JavaWeb中,HttpServletRequest与HttpServletResponse几乎是处理各种请求与操作必备的参数,与原始的ServletRequest/ServletResponse相 ...
- C. Make It Equal
链接 [http://codeforces.com/contest/1065/problem/C] 题意 给你n个高度hi的塔,让你把高的部分切掉,使得最后所有塔一样高,而且每次切的高度之和不大于k ...
- 安装Visual Studio2013
安装Visual Studio2013现在官网下载在选择安装的可选功能这里,大家可以根据自己需要勾选,也可以默认全选.这里有个小功能,把鼠标放在文字上,会弹出各个功能的详细描述.选择四个常用的功能,另 ...
- M2事后分析
计划 1. 你原计划的工作是否最后都做完了? 如果有没做完的,为什么? 修复了M1阶段的bug,整合前两组的数据.扩充功能,和学霸组达成功能上的一致,对数据库进行信息的完善. 2. 有没有发现你做了一 ...
- Java实验报告一:Java开发环境的熟悉
实验要求: 1. 使用JDK编译.运行简单的Java程序 2.使用Eclipse 编辑.编译.运行.调试Java程序 实验内容 (一) 命令行下Java程序开发 (二)Eclipse下Java程序 ...
- Minimum Integer CodeForces - 1101A (思维+公式)
You are given qq queries in the following form: Given three integers lili, riri and didi, find minim ...
- 在web.xml中配置监听器来控制ioc容器生命周期
5.整合关键-在web.xml中配置监听器来控制ioc容器生命周期 原因: 1.配置的组件太多,需保障单实例 2.项目停止后,ioc容器也需要关掉,降低对内存资源的占用. 项目启动创建容器,项目停止销 ...
- SpringMVC一例 是否需要重定向
在ASP.NET MVC下: return view("List") 和 return RedirectToAction("List") 百度知道的最佳答案: ...
- Python 零基础 快速入门 趣味教程 (咪博士 海龟绘图 turtle) 6. 条件
前面的教程中,我们已经可以让小海龟绘制出各种图形了.但是,所有绘图的代码都是预先编好的,程序一旦运行起来,运行结果(绘制的图形)就是固定不变的.这一节中,咪博士将教大家如何让海龟响应用户的输入. im ...
- 牛客网练习赛7-B-购物
在遥远的东方,有一家糖果专卖店. 这家糖果店将会在每天出售一些糖果,它每天都会生产出m个糖果,第i天的第j个糖果价格为C[i][j]元. 现在的你想要在接下来的n天去糖果店进行选购,你每天可以买多个糖 ...