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');
  }
}
相关推荐
zzz_236818 小时前
【Java实习面试算法冲刺】哈希!
java·算法·面试
大耳朵糊涂18 小时前
找前/后驱节点
算法
孤狼warrior18 小时前
从冒泡到传送带流水线:一个3D沉浸式算法靶场,让思想的伟力改变世界
python·算法·typescript
bu_shuo18 小时前
计算机二级学习-查找和排序
学习·算法·排序算法
Sam092719 小时前
【AI 算法精讲 13】朴素贝叶斯:文本分类的基石
人工智能·python·算法·ai
SilentSamsara19 小时前
模型可解释性业务化:SHAP/LIME 的业务汇报与合规审查
人工智能·算法·机器学习·自动化
byte轻骑兵19 小时前
【LE Audio】CSIP精讲[5]: 蓝牙协同设备组的安全防护体系与实战规范
算法·安全·音频·le audio·低功耗音频
剑挑星河月19 小时前
35.搜索插入位置
java·数据结构·算法·leetcode
闪电悠米19 小时前
力扣hot100-438.找到字符串中所有字母异位词-固定长度滑动窗口详解
linux·服务器·数据结构·算法·leetcode·滑动窗口·力扣hot100
人道领域19 小时前
【LeetCode刷题日记】51.N皇后
数据结构·算法