UVA-1152 和为0的4个值 题解答案代码 算法竞赛入门经典第二版

GitHub - jzplp/aoapc-UVA-Answer: 算法竞赛入门经典 例题和习题答案 刘汝佳 第二版

使用了算法竞赛入门经典第二版上介绍的方法:

一共有四个集合。先将前两个集合的元素两两相加,组成一个长度为n*n的数组,然后将这个数字排序好。这里耗时n^2和nlogn,最后时间复杂度为n^2。

然后再遍历后两个集合中的每个元素,两两相加,和为sum。如果在上面排序好的数组中找到一个值为-sum,那说明找到一个和为0的情况。由于排序好的数组中可能有重复元素,因此需要找到对应值的上界和下界。这里用二分查找方法,书中前面也讲过。这里的时间复杂度是n^2logn。

因此总复杂度是n^2logn。

AC代码

cpp 复制代码
#include <stdio.h>
#include <stdlib.h>

int arr[4][4100];
int n;
int count = 0;
int addArr[17000000];

int compare(const void *left, const void *right)
{
  return *(int *)left - *(int *)right;
}

int lowerBound(int num)
{
  int beg = 0, end = n * n, mid;
  while (end > beg)
  {
    mid = beg + (end - beg) / 2;
    if (addArr[mid] >= num)
      end = mid;
    if (addArr[mid] < num)
      beg = mid + 1;
  }
  return beg;
}

int upperBound(int num)
{
  int beg = 0, end = n * n, mid;
  while (end > beg)
  {
    mid = beg + (end - beg) / 2;
    if (addArr[mid] > num)
      end = mid;
    if (addArr[mid] <= num)
      beg = mid + 1;
  }
  return beg;
}

void computed()
{
  int i, j, sum, upper, lower;
  for (i = 0; i < n; ++i)
  {
    for (j = 0; j < n; ++j)
      addArr[i * n + j] = arr[0][i] + arr[1][j];
  }
  qsort(addArr, n * n, sizeof(int), compare);
  for (i = 0; i < n; ++i)
  {
    for (j = 0; j < n; ++j)
    {
      sum = arr[2][i] + arr[3][j];
      upper = upperBound(-sum);
      lower = lowerBound(-sum);
      count += upper - lower;
    }
  }
}

int main()
{
  int t, i, j;
  scanf("%d", &t);
  while (t--)
  {
    scanf("%d", &n);
    for (i = 0; i < n; ++i)
    {
      for (j = 0; j < 4; ++j)
        scanf("%d", &arr[j][i]);
    }
    count = 0;
    computed();
    printf("%d\n", count);
    if (t != 0)
      putchar('\n');
  }
}
相关推荐
leoufung2 小时前
LeetCode 76:Minimum Window Substring 题解与滑动窗口思维详解
算法·leetcode·职场和发展
小O的算法实验室2 小时前
2026年IEEE TETCI,山区环境下基于双种群进化的协同无人机巡逻任务协同优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
你撅嘴真丑2 小时前
map 与 set容器的应用--话题焦点人物
数据结构
生成论实验室2 小时前
《事件关系阴阳博弈动力学:识势应势之道》第二篇:阴阳博弈——认知的动力学基础
数据结构·人工智能·科技·神经网络·算法
li1670902702 小时前
第二十七章:智能指针
c语言·数据结构·c++·visual studio
风筝在晴天搁浅3 小时前
字节高频题 小于n的最大数
算法
LabVIEW开发3 小时前
LabVIEW水力机组空蚀在线监测
算法·labview·labview知识·labview功能·labview程序
AI科技星3 小时前
科幻艺术书本封面:《全域数学》第一部·数术本源 第三卷 代数原本(P95-141)完整五级目录【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
风筝在晴天搁浅3 小时前
LeetCode 92.反转链表Ⅱ
算法·leetcode·链表