这道题我苦思冥想了一个小时, 想用背包来揍sum/2, 然后发现数据太大, 空间存不下。

然后我最后还是去看了别人的博客, 发现竟然有个神奇的结论……

幸好我没再钻研, 感觉这个结论我肯定是想不到的……

结论是:在1 <= a[i] <= i时, 前i个数一定可以凑出1~sum[i]的所有整数

证明看这 https://blog.csdn.net/wcr1996/article/details/43957461

其他博客写有了这个结论, 就排序一下, 从大到小, 凑sum/2, 能凑就凑, 最后一定可以凑成。

但是我开始一直想不通为啥这样下去一定可以凑成, 为什么要排序??其他博客貌似没有

给出解释……

然后我自己思考了挺久, 想通了。

首先这个结论证明一定可以揍成sum/2(sum为奇数不考虑, 输出No)

然后, 从大到小排序。

假设第一个可以凑的数为a[k], a[k]显然是第一个小于等于sum/2的数

也就是说a[k]之前的数, 也就是所有大于a[k]的数, 都大于sum/2

也就是说这些数不可能来揍sum/2.

然后sum/2就减去了a[k]。那么a[k]之后的数一定可以凑sum/2-a[k];

为什么呢?这里是关键。

因为要凑sum/2-a[k]的数字肯定小于sum/2-a[k], 而这些数字一定在a[k]之后

因为a[k]是第一个小于等于sum/2的数, 那么第一个小于等于sum/2-a[k]的数字

肯定小于等于a[k], 也就肯定在a[k]后面。

所以要凑成sum/2-a[k]的数都在a[k]后面, 这些数字还没有被选到。

因为开始的结论说明肯定可以凑sum/2-a[k], 而所有需要来凑

sum/2-a[k]的数还没有遍历到。

所以, sum/2-a[k]一定可以用还没遍历到的数凑成。

以此类推, 一直做下去, 肯定可以凑完

over!!!!!!!!!!


  1. #include<cstdio>
  2. #include<algorithm>
  3. #define REP(i, a, b) for(int i = (a); i < (b); i++)
  4. using namespace std;
  5. const int MAXN = 112345;
  6. int a[MAXN], id[MAXN], n;
  7. bool cmp(int x, int y)
  8. {
  9. return a[x] > a[y];
  10. }
  11. int main()
  12. {
  13. while(~scanf("%d", &n))
  14. {
  15. long long sum = 0;
  16. REP(i, 0, n)
  17. {
  18. scanf("%d", &a[i]);
  19. sum += a[i];
  20. id[i] = i;
  21. }
  22. if(sum & 1) { puts("No"); continue; }
  23. sort(id, id + n, cmp);
  24. sum >>= 1;
  25. REP(i, 0, n)
  26. {
  27. int t = id[i];
  28. if(a[t] <= sum)
  29. {
  30. sum -= a[t];
  31. a[t] = 1;
  32. }
  33. else a[t] = -1;
  34. }
  35. puts("Yes");
  36. REP(i, 0, n) printf("%d ", a[i]);
  37. puts("");
  38. }
  39. return 0;
  40. }

紫书 习题8-10 UVa 1614 (贪心+结论)的更多相关文章

  1. 紫书 习题8-12 UVa 1153(贪心)

    本来以为这道题是考不相交区间, 结果还专门复习了一遍前面写的, 然后发现这道题的区间是不是 固定的, 是在一个范围内"滑动的", 只要右端点不超过截止时间就ok. 然后我就先考虑有 ...

  2. 紫书 习题 11-9 UVa 12549 (二分图最小点覆盖)

    用到了二分图的一些性质, 最大匹配数=最小点覆盖 貌似在白书上有讲 还不是很懂, 自己看着别人的博客用网络流写了一遍 反正以后学白书应该会系统学二分图的,紫书上没讲深. 目前就这样吧. #includ ...

  3. 紫书 习题 11-8 UVa 1663 (最大流求二分图最大基数匹配)

    很奇怪, 看到网上用的都是匈牙利算法求最大基数匹配 紫书上压根没讲这个算法, 而是用最大流求的. 难道是因为第一个人用匈牙利算法然后其他所有的博客都是看这个博客的吗? 很有可能-- 回归正题. 题目中 ...

  4. 紫书 习题8-7 UVa 11925(构造法, 不需逆向)

    这道题的意思紫书上是错误的-- 难怪一开始我非常奇怪为什么第二个样例输出的是2, 按照紫书上的意思应该是22 然后就不管了,先写, 然后就WA了. 然后看了https://blog.csdn.net/ ...

  5. 紫书 习题 8-13 UVa 10570 (枚举+贪心)

    我看到数据范围只有500, 第一反应枚举所有的可能,然后求出每种可能的最小次数. 但是不知道怎么求最小次数.我想的是尽量让一次交换可以让两个不在应该在的位置的数字 到原来应该在的位置的数字, 这样可以 ...

  6. 紫书 习题8-8 UVa 1612 (贪心+精度)

    这道题我很快就写出来了, 但是一直WA, 然后发现是精度, 这坑了我一个小时-- (1)贪心.每次就尽量分数高, 可以保证最后分数最高 (2)神tm精度问题.记住判断大于小于和等于的时候要用EPS(1 ...

  7. 紫书 习题8-4 UVa 11491 (贪心)

    题意:给你一个数, 要求删去一些数字, 使得剩下的数字最大. 这道题用贪心解决. 大家想一想, 两个数比较大小, 肯定先比较第一位的数,然后依次比较第二位,以此类推. 既然我们要保证最后的数字最大, ...

  8. 紫书 习题 8-23 UVa 1623 (set妙用 + 贪心)

    这道题我是从样例中看出思路了 2 4 0 0 1 1 看这组数据, 输出的是No, 为什么呢?因为两个1之间没有神龙喝水, 所以一定会有水灾. 然后就启发了我,两次同一个湖的降水之间必须至少有一次神龙 ...

  9. 紫书 习题 8-15 UVa 1617 (贪心)

    先排序, 然后每个线段先放右端点, 然后往下放, 如果不能放就整体往左移动, 当不能往左移动的时候就ans++ 开始下一个整块.判断能不能向左移动要用一个变量储存每个已经放了的区间中线段与左端点距离的 ...

随机推荐

  1. Facebook再次爆出安全漏洞,9000万用户受影响

    今年上半年开始,美国社交媒体Facebook因数据泄露事件和涉嫌操纵选举等问题频繁接受听证会拷问,然而事情却远没有结束.今年9月Facebook再次爆出安全漏洞,导致9000万用户可能受到影响. 根据 ...

  2. ArcGIS探索

    一.ArcGIS10概述 1.1 总览 ArcGIS是地理信息系统平台软件,主要用于创建和使用地图,编辑和管理地理数据,分析和共享地理信息,并在一系列应用中使用地图和地理信息. 功能定位: a.地图: ...

  3. 微信企业号开发:微信用户信息和web网页的session的关系

         微信企业号的用户是须要验证的,因此能关注企业号的用户事实上就是已经通过验证的用户.但企业应用中打开一个网页,在这个网页中怎样依据微信用户的信息创建web应用中最长使用的session呢?微信 ...

  4. 怎样在Web项目中的service业务层获取项目根路劲

    这里我们有两个前提 1.没有使用struts2框架.没有使用servlet,无法给service层传递request对象. 2.使用了Spring框架. 那你可能问.会有这样的情况吗?答案是有的,比方 ...

  5. Asp.net button防止点击多次数据提交

     <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head runat= ...

  6. dotnet core test with NUnit

    https://github.com/nunit/dotnet-test-nunit if you are using Visual Studio. Your project.json in your ...

  7. CNN tflearn处理mnist图像识别代码解说——conv_2d参数解释,整个网络的训练,主要就是为了学那个卷积核啊。

    官方参数解释: Convolution 2D tflearn.layers.conv.conv_2d (incoming, nb_filter, filter_size, strides=1, pad ...

  8. BZOJ 2301 莫比乌斯函数+分块

    思路: 同BZOJ1101 就是加个容斥 - http://blog.csdn.net/qq_31785871/article/details/54340241 //By SiriusRen #inc ...

  9. VC6之MAP文件生成及格式

    文件生成方式: 在 VC 中,我们可以按下 Alt+F7 ,打开“Project Settings”选项页,选择 C/C++ 选项卡,并在最下面的 Project Options 里面输入:/Zd , ...

  10. javaBean 练习—封装学生信息

    编写一个封装学生信息的JavaBean对象,在页面中调用该对象,并将学生信息输出在页面中. package com.sp.test; public class Student { private St ...