• 刷题记录(NC24017 [USACO 2016 Jan S]Angry Cows,NC16462 [NOIP2015]跳石头,NC235254 晾衣服)


    NC24017 [USACO 2016 Jan S]Angry Cows

    题目链接

    关键点:

    1、要求爆炸半径的最小值,二分答案,每次判断

    2、如何判断:先将距离排序(从小到大),然后设最左边(l)为第一个数组(grass[1]),接下来让l+=r*2(加上两个半径),这是最大利用爆炸面积的做法,然后去找在这个l之后的第一个grass,再次爆炸,判断在有限的奶牛数量中,爆炸的最大距离是否会大于最后一个干草堆的坐标

    1. # include
    2. # include
    3. # include
    4. using namespace std;
    5. typedef long long ll;
    6. const int N = 50000+10;
    7. int n, k;
    8. int grass[N];
    9. int judge(ll x)
    10. {
    11. ll l = grass[1];
    12. // cout<
    13. for (int i=1; i<=k; i++)
    14. {
    15. l += x*2;
    16. if (l>=grass[n])
    17. {
    18. return 1;
    19. }
    20. int ans = *upper_bound(grass+1, grass+1+n, l);
    21. l = ans;
    22. // cout<
    23. }
    24. return 0;
    25. }
    26. int main()
    27. {
    28. cin>>n>>k;
    29. for (int i=1; i<=n; i++)
    30. cin>>grass[i];
    31. sort(grass+1, grass+1+n);
    32. ll l = 0, r = 1000000010;
    33. while (l<=r)
    34. {
    35. ll mid = (l+r)/2;
    36. // cout<
    37. if (judge(mid)) r = mid-1;
    38. else l = mid+1;
    39. }
    40. cout<1<
    41. return 0;
    42. }

    NC16462 [NOIP2015]跳石头

    题目链接

    关键点

    1、求最短跳跃距离的最大值,一样的二分答案再验证

    2、如何验证,求在该最短跳跃距离下,是否还会出现更短的跳跃距离,如果出现,则将石头搬走,如果搬走石头的次数超出所给出的次数,那么当前的跳跃距离就不行

    完整代码

    1. # include
    2. # include
    3. using namespace std;
    4. typedef long long ll;
    5. int len, m, n;
    6. int rock[500000+10];
    7. int judge(int x)
    8. {
    9. int start = 0;
    10. int now = 0;
    11. for (int i=1; i<=n; i++)
    12. {
    13. int dis = rock[i]-start;
    14. if (dis
    15. {
    16. now++;
    17. }
    18. else
    19. start = rock[i];
    20. if (now>m)
    21. {
    22. return 0;
    23. }
    24. }
    25. int dis = len-rock[n];
    26. if (dis
    27. now++;
    28. if (now>m)
    29. return 0;
    30. return 1;
    31. }
    32. int main()
    33. {
    34. cin>>len>>n>>m;
    35. for (int i=1; i<=n; i++)
    36. cin>>rock[i];
    37. ll l = 0, r = 1000000000+10;
    38. while (l<=r)
    39. {
    40. ll mid = (l+r)/2;
    41. if (judge(mid)) l = mid+1;
    42. else r = mid-1;
    43. }
    44. cout<-1<
    45. return 0;
    46. }

    NC235254 晾衣服

    题目链接

    关键点

    1、一样的二分最短晾衣服的时间

    2、判断,如果能在当前二分的时间里使衣服晾干,那么该衣服就不要用烘干机,如果不能晾干,那么就求要占用的机子的时间(注意用ceil向上取整),然后求总共要用吹风机的时间,注意因为在最开始求是否存在自然干的衣服时,已经将所有的衣服都在该分钟内的水量减去了1,所以这是再算吹风机的效果时,再减去k-1即可,如果超出了所给的时间,那么就不行,

    3、要注意判断如果吹风机的烘干数(k)为1时,直接输出最长晾干的衣服的水量即可

    完整代码

    1. # include
    2. # include
    3. # include
    4. # include
    5. using namespace std;
    6. typedef long long ll;
    7. ll n, k;
    8. int maxx;
    9. int a[100000+10];
    10. int judge(ll x)
    11. {
    12. ll total = 0;
    13. for (int i=1; i<=n; i++)
    14. {
    15. if (a[i]>x)
    16. total+=(ceil((a[i]-x)*1.0/(k-1)));
    17. }
    18. if (total<=x)
    19. return 1;
    20. else
    21. return 0;
    22. }
    23. int main()
    24. {
    25. scanf("%d", &n);
    26. for (int i=1; i<=n; i++)
    27. {
    28. scanf("%d", &a[i]);
    29. maxx = max(maxx, a[i]);
    30. }
    31. scanf("%d", &k);
    32. if (k==1)
    33. {
    34. cout<
    35. return 0;
    36. }
    37. ll l = 0, r = maxx;
    38. while (l<=r)
    39. {
    40. ll mid = (r+l)/2;
    41. if (judge(mid)) r = mid-1;
    42. else l = mid+1;
    43. }
    44. cout<1<
    45. return 0;
    46. }

  • 相关阅读:
    16.linux应用实现控制led
    8. Go的函数
    RecyclerView 刷新Item图片闪烁
    Qt 子线程中无限递归的信号槽导致主线程槽失效的原因和解决办法
    【LittleXi】C程序预处理、编译、汇编、链接步骤
    JAVA计算机毕业设计电子书店管理系统Mybatis+系统+数据库+调试部署
    SpringCloud学习笔记-Nacos服务分级存储模型
    Google Earth Engine(GEE)—— Landsat7和8的2000-2021年的影像土地分类的下载和视频导出
    从Architecture带你认识JVM
    论文笔记: 度量学习基本理解
  • 原文地址:https://blog.csdn.net/m0_60531106/article/details/125902400