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');
  }
}
相关推荐
‎ദ്ദിᵔ.˛.ᵔ₎34 分钟前
双指针、滑动窗口、前缀和、二分查找 算法
算法
顾北顾1 小时前
多头注意力机制
人工智能·深度学习·算法
H178535090961 小时前
SolidWorks_基于草图的实体特征20_特征错误排查
算法·3d建模·solidworks
hujinyuan201601 小时前
2025年12月中国电子学会青少年机器人技术等级考试试卷(二级) 真题+答案
人工智能·算法·机器人
bIo7lyA8v2 小时前
算法复杂度评估的实验统计方法与可视化的技术8
算法
李老师讲编程2 小时前
中国电子学会图形化2020.12月Scratch三级考级题
算法·scratch·信息学奥赛·图形化编程·scratch素材
退休倒计时3 小时前
【每日一题】LeetCode 53. 最大子数组和 TypeScript
数据结构·算法·leetcode·typescript
旖-旎3 小时前
FloodFill(图像渲染)(1)
c++·算法·深度优先·力扣
戴西软件3 小时前
戴西 DLM 许可授权管理系统:破解无网络环境下工业软件授权难题,助力制造企业降本增效
网络·人工智能·python·深度学习·程序人生·算法·制造