题意

题目链接

给出长度为\(n\)的序列\(a\),序列中的元素取值为\([-2e9, 2e9]\)

找到两个位置\((i, j) (i <j, a[i] < a[j])\),最小化\(a[i] * a[j]\)

Sol

当时在做的时候思路是直接维护大于\(0\)的最大/最小值,小于\(0\)的最大/最小值然从这四个里面转移

然而是有反例的,比如\(-100, -3, -5, -4\)

当时没有仔细往下想。

出现错误的本质原因还是因为负负的正的性质。

那么我们直接来分类讨论一下

整个序列可以分成四种情况

  • 全为正

这时候直接维护出前缀最小值

  • 存在一个位置为正数且前面有负数

同样维护前缀最小值

  • 前一半为正后一半为负

可分成两段分别做

  • 全为负

这是我自己没想出来的,看了dyh的代码只能Orzzz

这时候我们倒着考虑,不难发现一个小于\(0\)的数,乘上小于\(0\)的最大的数,得到的数一定是最小的。

那么直接维护一下最大值就好了。

#include<bits/stdc++.h>
#define LL long long
//#define int long long
#define uint unsigned int
#define chmax(a, b) (a = (a > b ? a : b))
#define chmin(a, b) (a = (a < b ? a : b))
using namespace std;
const int MAXN = 1e7 + 10;
LL mod = 1ll << 32, INF = 9223372036854775806;
inline LL read() {
char c = getchar(); LL x = 0, f = 1;
while(c < '0' || c > '9') {if(c == '-') f = -1; c = getchar();}
while(c >= '0' && c <= '9') x = x * 10 + c - '0', c = getchar();
return x * f;
}
int N;
LL L, R, X, Y, Z, a[MAXN];
uint b[MAXN];
LL add(LL x, LL y) {
if(x + y < 0) return x + y + mod;
return x + y >= mod ? x + y - mod : x + y;
}
LL mul(LL x, LL y) {
return 1ll * x * y % mod;
}
void solve() {
N = read();
L = read(); R = read(); X = read(); Y = read(); Z = read(); b[1] = read(); b[2] = read();
for(int i = 3; i <= N; i++) b[i] = (b[i - 2] * X % mod + b[i - 1] * Y % mod + Z) % mod;
for(int i = 1; i <= N; i++) a[i] = b[i] % (R - L + 1) + L;
//puts("");for(int i = 1; i <= N; i++) printf("%d ", a[i]);
//'for(int i = 1; i <= N; i++) a[i] = read();
LL mn = INF, ans = INF;
//cout << ans << endl;
for(int i = 1; i <= N; i++) {
if(mn < a[i]) chmin(ans, mn * a[i]);
chmin(mn, a[i]);
}
mn = -INF;
for(int i = N; i >= 1; i--) {
if(a[i] < mn) chmin(ans, mn * a[i]);
chmax(mn, a[i]);
}
if(ans == INF) printf("IMPOSSIBLE\n");
else cout << ans << endl;
}
signed main() {
for(int T = read(); T; T--, solve());
return 0;
}

cf1090 I.Minimal Product(贪心)的更多相关文章

  1. uva.10020 Minimal coverage(贪心)

    10020 Given several segments of line (int the X axis) with coordinates [Li, Ri]. You are to choose t ...

  2. UVA 10020 Minimal coverage(贪心 + 区间覆盖问题)

     Minimal coverage  The Problem Given several segments of line (int the X axis) with coordinates [Li, ...

  3. ural 1303 Minimal Coverage(贪心)

    链接: http://acm.timus.ru/problem.aspx?space=1&num=1303 按照贪心的思想,每次找到覆盖要求区间左端点时,右端点最大的线段,然后把要求覆盖的区间 ...

  4. CodeForce-797C Minimal string(贪心模拟)

    Minimal string CodeForces - 797C Petya 收到一个长度不超过 105 的字符串 s.他拿了两个额外的空字符串 t 和 u 并决定玩一个游戏.这个游戏有两种合法操作: ...

  5. Minimal coverage (贪心,最小覆盖)

    题目大意:先确定一个M, 然后输入多组线段的左端和右端的端点坐标,然后让你求出来在所给的线段中能够 把[0, M] 区域完全覆盖完的最少需要的线段数,并输出这些线段的左右端点坐标. 思路分析: 线段区 ...

  6. Codeforces Round #667 (Div. 3) B. Minimum Product (贪心,数学)

    题意:给你\(a\)和\(b\)两个数,每次操作可以是任意一个数\(-1\),最多操作\(n\),并且\(a\ge x\),\(b\ge y\),求操作后\(a*b\)的最小值. 题解:观察样例并且在 ...

  7. Contest 7.21(贪心专练)

    这一次都主要是贪心练习 练习地址http://acm.hust.edu.cn/vjudge/contest/view.action?cid=26733#overview Problem APOJ 13 ...

  8. 2018-2019 Russia Open High School Programming Contest

    A. Company Merging Solved. 温暖的签到. #include<bits/stdc++.h> using namespace std; ; typedef long ...

  9. 2018-2019 Russia Open High School Programming Contest (Unrated, Online Mirror, ICPC Rules, Teams Preferred)

    前言 有一场下午的cf,很滋磁啊,然后又和dalao(见右面链接)组队打了,dalao直接带飞我啊. 这是一篇题解,也是一篇总结,当然,让我把所有的题目都写个题解是不可能的了. 按照开题顺序讲吧. 在 ...

随机推荐

  1. iOS几个功能:1.摇一摇;2.震动;3.简单的摇动动画;4.生成二维码图片;5.发送短信;6.播放网络音频等

    有一个开锁的功能,具体的需求就类似于微信的“摇一摇”功能:摇动手机,手机震动,手机上的锁的图片摇动一下,然后发送开锁指令.需求简单,但用到了许多方面的知识. 1.摇一摇 相对这是最简单的功能了. 在v ...

  2. Flink学习笔记-新一代Flink计算引擎

    说明:本文为<Flink大数据项目实战>学习笔记,想通过视频系统学习Flink这个最火爆的大数据计算框架的同学,推荐学习课程: Flink大数据项目实战:http://t.cn/EJtKh ...

  3. 解决Python向MySQL数据库插入中文数据时出现乱码

    解决Python向MySQL数据库插入中文数据时出现乱码 先在MySQL命令行中输入如下语句查看结果: 只要character_set_client character_set_database ch ...

  4. (C/C++) Array 印出所有排列組合

    #include <stdio.h> #include <stdlib.h> #define N 4 , , , }; void swap(int *a, int *b) { ...

  5. noip | 题目 | noip数据 收集站 | noipdata

    这是什么 一个NOIP历年比赛数据及题目的收集站,方便大家查找使用 网站链接:https://noipdata.github.io 点击这里立即跳转 新连接:noipdata.rcxzsc.com 点 ...

  6. 解决flex布局下, elementui table组件不能跟随父组件的宽度而变化的bug

    bug: 我在flex布局的元素中使用了elementui的table组件,饿了么的table上会被加一个动态的宽度, 当第一次改变flex元素宽度的时候.table的动态宽度会变化,第二次和以后就不 ...

  7. (java/javascript) list 交集 并集 差集 去重复并集

    java list 交集 并集 差集 去重复并集 package com; import java.util.ArrayList; import java.util.Iterator; import ...

  8. Spring Boot Starters是什么?

    版权声明:该文转自: http://www.nosuchfield.com/2017/10/15/Spring-Boot-Starters/.版权归原创作者,在此对原作者的付出表示感谢! starte ...

  9. IO流(二)字符流

    1.字符流:在字节流的基础上添加了编码机制.很大程度上和字节流操作一样的,字符流只能操作文本类文件,准确的说应该是纯文本类文件.例如.txt,.java,.cpp,.html等 编码:每一个国家都有自 ...

  10. 弗格森&红魔

    本周日曼联对阵斯旺西时,一位名叫皮特-莫利纽克斯的58岁老人,将会举起一张老旧的床单,就如他曾做过的那样.那一次“臭名昭着”的行为要追溯到1989年12月,弗格森当时已经来到了悬崖边上,他的背后是一堵 ...