码迷,mamicode.com
首页 > 其他好文 > 详细

(白书训练计划)UVa 1152 4 Values whose Sum is 0(中途相遇法。。)

时间:2014-09-03 21:22:17      阅读:324      评论:0      收藏:0      [点我收藏+]

标签:acm   c语言   算法   编程   

题目地址:UVa 1152

先枚举A集合与B集合的和,存起来,然后再枚举C集合与D集合的和,看与存起来的值有多少个是互为相反数的。水题。找存起来的值时可以用二分找。

代码如下:

#include <iostream>
#include <cstdio>
#include <string>
#include <cstring>
#include <stdlib.h>
#include <math.h>
#include <ctype.h>
#include <queue>
#include <map>
#include <set>
#include <algorithm>

using namespace std;
int a[5000], b[5000], c[6000], d[6000], p[17000000];
int main()
{
    int t, n, m, ans, i, j, k;
    scanf("%d",&t);
    while(t--)
    {
        scanf("%d",&n);
        m=0;
        for(i=0;i<n;i++)
        {
            scanf("%d%d%d%d",&a[i],&b[i],&c[i],&d[i]);
        }
        for(i=0;i<n;i++)
        {
            for(j=0;j<n;j++)
            {
                p[m++]=a[i]+b[j];
            }
        }
        sort(p,p+m);
        int low, high, mid;
        ans=0;
        for(i=0;i<n;i++)
        {
            for(j=0;j<n;j++)
            {
                int x=-c[i]-d[j];
                low=0, high=m-1;
                while(low<=high)
                {
                    mid=low+high>>1;
                    if(p[mid]>x) high=mid-1;
                    else if(p[mid]<x) low=mid+1;
                    else
                    {
                        for(k=mid;k>=0;k--)
                        {
                            if(p[k]==x)
                            {
                                ans++;
                            }
                            else
                                break;
                        }
                        for(k=mid+1;k<m;k++)
                        {
                            if(p[k]==x)
                            {
                                ans++;
                            }
                            else
                                break;
                        }
                        break;
                    }
                }
            }
        }
        printf("%d\n",ans);
        if(t)
            puts("");
    }
    return 0;
}


(白书训练计划)UVa 1152 4 Values whose Sum is 0(中途相遇法。。)

标签:acm   c语言   算法   编程   

原文地址:http://blog.csdn.net/scf0920/article/details/39032021

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!