【u207】最小值
Time Limit: 1 second
Memory Limit: 128 MB
【问题描述】
N个数排成一排,你可以任意选择连续的若干个数,算出它们的和。问该如何选择才能使得和的绝对值最小。
如:N=8时,8个数如下:
1 2 3 4 5 6 7 8
-20 90 -30 -20 80 -70 -60 125
如果我们选择1到4这4个数,和为20,还可以选择6到8这3个数,和为-5,|-5|=5,该方案获得的和的绝对值最小。
【输入格式】
第一行输入N,表示数字的个数。接下来N行描述这N个数字。
【输出格式】
第一行输出一个整数,表示最小绝对值的和,第二行包含两个整数表示形成该绝对值和最长序列的长度。
【数据规模】
40%的数据 N<=4000 对于许多数据,最长序列的长度唯一。 100%的数据 N<=100000,|每个数字的值|<=10^10
Sample Input1
20
12
-220
-195
-316
-300
668
576
1034
1055
972
-1023
866
-1469
492
857
1954
1685
1046
-1748
-1480
Sample Output1
12
1
【题解】 对于区间的静态查询。要用前缀和的方法。 sum[i]=sum[i-1]+data[i]; 然后处理出sum[0..n]注意要把sum[0]也处理出来。 然后把这n+1个sum从小到大或从大到小排序。排序完之后。可以保证序列最小和 就是min{abs(sum[i]-sum[i-1])}其中i∈(1..10); 因为排序之后相邻的sum值是最接近的。 然后要记录sum对应的i。 最大sum相同时。就让他们的差的绝对值最大就好。 如果全是正数则不用排序。因为sum会越来越大。。这样。 用__int64之后oj才让过了。。 【代码】#include <cstdio>
#include <algorithm> using namespace std; struct node //pos用于记录是哪一个位置的前缀和。
{
__int64 what;
int pos;
}; int n,maxl;
__int64 x, minn;
node sum[100001]; //用于存储前缀和。 void input_data()
{
scanf("%d", &n);
sum[0].what = 0; //前0个元素的和也要加进去。
sum[0].pos = 0; //不然没法单独取到第一个元素。
for (int i = 1; i <= n; i++) //输入n个数字记录前缀和
{
scanf("%I64d", &x); //这是__int64的输入格式。
sum[i].what = sum[i - 1].what + x;
sum[i].pos = i;
}
} int cmp(const node &a, const node &b) //sort函数的对比函数
{
if (a.what < b.what)
return 1;
return 0;
} int abs(int x) //返回x的绝对值。
{
return x < 0 ? -x : x;
} void get_ans()
{
minn = sum[1].what; //一开始先处理最小值是第一个。
if (minn < 0)
minn = -minn;
maxl = sum[1].pos; //记录下他的长度。
for (int i = 2; i <= n; i++) //枚举每两个前缀和的差的绝对值
{
__int64 temp = sum[i].what - sum[i - 1].what;
int temp2 = abs(sum[i].pos - sum[i - 1].pos);
if (temp < minn) //尝试更新最小值。
{
minn = temp;
maxl = temp2;
}
else //如果相同则看是否长度更长
if (temp == minn && temp2 > maxl)
maxl = temp2;
}
} void output_ans()
{
printf("%I64d\n", minn);
printf("%d", maxl);
} int main()
{
//freopen("F:\\rush.txt", "r", stdin);
//freopen("F:\\rush_out.txt", "w", stdout);
input_data();
sort(sum + 0, sum + 1+n, cmp);//要对sum[0..n]都进行排序。
get_ans();
output_ans();
//fclose(stdin);
//fclose(stdout);
return 0;
}
【u207】最小值的更多相关文章
- C语言 · 最大值与最小值计算
输入11个整数,计算它们的最大值和最小值. 样例输入 0 1 2 3 4 5 6 7 8 9 10 样例输出 10 0 #include<stdio.h> int main(){ ]; ...
- [LeetCode] Find Minimum in Rotated Sorted Array II 寻找旋转有序数组的最小值之二
Follow up for "Find Minimum in Rotated Sorted Array":What if duplicates are allowed? Would ...
- [LeetCode] Find Minimum in Rotated Sorted Array 寻找旋转有序数组的最小值
Suppose a sorted array is rotated at some pivot unknown to you beforehand. (i.e., 0 1 2 4 5 6 7 migh ...
- 整理:Javascript获取数组中的最大值和最小值的方法汇总
方法一: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 //最小值 Array.prototype.min = function ...
- 不需要sql进行计算数据的平均值、最大值、最小值、和
介绍下SqlServer.前端js.后台C#三个阶段对均值.最大值.最小值.和计算int[] jisuan = {0, 1, 3, 5, 7,8 }; List<int> jisuan2 ...
- call和apply求最大和最小值
,取最大值 var arr = [1,3,7,22,677,-1,2,70]; Math.max.apply(Math, arr);//677 Math.max.call(Math, 1,3,7,22 ...
- 【Oracle】oracle取最大值和最小值的几个方法汇总
(1)oracle使用keep分析函数取最值记录 -- 取工资sal最大的雇员姓名及其工资,以及工资sal最少的雇员姓名及其工资 select deptno, empno, ename, sal, m ...
- 关于过拟合、局部最小值、以及Poor Generalization的思考
Poor Generalization 这可能是实际中遇到的最多问题. 比如FC网络为什么效果比CNN差那么多啊,是不是陷入局部最小值啊?是不是过拟合啊?是不是欠拟合啊? 在操场跑步的时候,又从SVM ...
- 使用Python scipy linprog 线性规划求最大值或最小值(使用Python学习数学建模笔记)
函数格式 scipy.optimize.linprog(c, A_ub=None, b_ub=None, A_eq=None, b_eq=None, bounds=None, method='simp ...
随机推荐
- 【Codeforces Round #447 (Div. 2) B】Ralph And His Magic Field
| [链接] 我是链接,点我呀:) [题意] 给你一个n*m矩阵,让你在里面填数字. 使得每一行的数字的乘积都为k; 且每一列的数字的乘积都为k; k只能为1或-1 [题解] 显然每个位置只能填1或- ...
- elementUI upload 对图片的宽高做校验
很开心今天中午没有吃饭!原因是一直没有解决掉一个小问题,于是一直试错,最后看了下源码才有了点头绪,历时四五个小时才解决掉,有点怀疑自己的能力了,所以写下此文,记录一下今天的囧况!一般情况下遇到问题,自 ...
- 苹果手机wifi代理设置方法--用于抓包
杯具了!@@@@@@@变态的公司不能直接上网了,但是经过我的研究.可以用代理上网,电脑是可以了,但是的iphone肿么办,哇咔咔,不要捉急,我来告诉你怎么让你的iphone通过代理上网.动起来吧. 请 ...
- 推荐一款稳定快速免费的前端开源项目 CDN 加速服务
前面学习到什么是CDN,全称是Content Delivery Network,即内容分发网络.CDN的通俗理解就是网站加速,CPU均衡负载. CDN的基本思路是尽可能避开互联网上有可能影响数据传输速 ...
- MySQL字符编码问题,Incorrect string value
MySQL上插入汉字时报错例如以下.详细见后面分析. Incorrect string value: '\xD0\xC2\xC8A\xBEW' for column 'ctnr' at row 1 M ...
- C#使用wkhtmltopdf.exe,HTML页面转化为PDF文档
此文用来记录使用wkhtmltopdf.exe在C#代码中将html转换为PDF的过程: 1,在http://wkhtmltopdf.org/downloads.html 下载wkhtmltopdf. ...
- python3中numpy函数tile的用法
tile函数位于python模块 numpy.lib.shape_base中,他的功能是重复某个数组.比如tile(A,n),功能是将数组A重复n次,构成一个新的数组,我们还是使用具体的例子来说明问题 ...
- 2、opencv2.4.13.6安装
一. 卸载opencv3.3.0: Going to the "build" folder directory of opencv from terminal, and execu ...
- iOS开发UI篇--一个侧滑菜单SlidingMenu
一.简介 侧滑菜单已经成为app一个极常用的设计,不管是事务类,效率类还是生活类app.侧滑菜单因Path 2.0和Facebook为开发者熟知,国内目前也有很多流行app用到了侧滑菜单,比如QQ.网 ...
- popen:让进程看似文件
popen打开一个指向进程的带缓冲的连接: FILE *fp; fp = popen("ls", "r"); fgets(buf, len, fp); pclo ...