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');
  }
}
相关推荐
oo哦哦15 小时前
搜索矩阵系统的最短路密码:用Dijkstra算法和网络流理论,解释为什么你做了1000个关键词,流量还不如别人30个
网络·算法·矩阵
Matlab程序猿小助手15 小时前
【MATLAB源码-第319期】基于matlab的帝王蝶优化算法(MBO)无人机三维路径规划,输出做短路径图和适应度曲线.
开发语言·算法·matlab
图码15 小时前
二分查找进阶:如何在有序数组中快速找到Upper Bound?
数据结构·算法·面试·分类·柔性数组
试剂界的爱马仕15 小时前
《古董局·终局5:潮生》第 2 章:镜子的天赋
大数据·人工智能·算法
Cthy_hy15 小时前
树状数组(BIT)进阶:差分优化实现区间修改、区间查询
数据结构·python·算法
YsyaaabB16 小时前
ACM 模式通用代码模板
java·c++·python·算法
ComputerInBook16 小时前
Euclid 几何变换——仿射(affine)变换
算法·仿射变换·几何变换
一只叁木Meow17 小时前
电商 SKU 选择器:用算法实现优雅的用户交互
前端·javascript·算法
代码中介商17 小时前
红黑树完全指南:从五条性质到完整插入删除实现
数据结构·算法
JieE21217 小时前
反转链表:从双指针到递归,吃透链表反转的核心逻辑
javascript·算法