1063. Set Similarity (25)

时间限制
300 ms
内存限制
32000 kB
代码长度限制
16000 B
判题程序
Standard
作者
CHEN, Yue

Given two sets of integers, the similarity of the sets is defined to be Nc/Nt*100%, where Nc is the number of distinct common numbers shared by the two sets,
and Nt is the total number of distinct numbers in the two sets. Your job is to calculate the similarity of any given pair of sets.

Input Specification:

Each input file contains one test case. Each case first gives a positive integer N (<=50) which is the total number of sets. Then N lines follow, each gives a set with a positive M (<=104) and followed by M integers in the range
[0, 109]. After the input of sets, a positive integer K (<=2000) is given, followed by K lines of queries. Each query gives a pair of set numbers (the sets are numbered from 1 to N). All the numbers in a line are separated
by a space.

Output Specification:

For each query, print in one line the similarity of the sets, in the percentage form accurate up to 1 decimal place.

Sample Input:

3
3 99 87 101
4 87 101 5 87
7 99 101 18 5 135 18 99
2
1 2
1 3

Sample Output:

50.0%
33.3%
解题思路:
输入数组后,根据输入的数组序号对数组进行排序,然后去重,再进行类似于merge操作的遍历,获得两个数组中不同的数的个数。

#include <iostream>
#include"stdio.h"
#include"stdlib.h"
#include"algorithm"
using namespace std; struct store{
    int a[10000];
    int length;
    bool sort_flag;//标记数组是否已经排序,可以避免重复排序
    int cnt;
};
int main()
{
    int N,M,K;
    struct store s[50];
    scanf("%d",&N);
    for(int i=0;i<N;i++){
        scanf("%d",&M);
        s[i].length = M;
        s[i].cnt=M;
        s[i].sort_flag = false;
        for(int j=0;j<M;j++){
            scanf("%ld",&s[i].a[j]);
        }
    }
    scanf("%d",&K);     int first,second;
    for(int k=0;k<K;k++){
        scanf("%d%d",&first,&second);
        first--;
        second--;
        if(!s[first].sort_flag){
            sort(s[first].a,s[first].a+s[first].length);//快排
            //去重
            for(int i=s[first].length-1;i>=1;i--){
                if(s[first].a[i]==s[first].a[i-1]){
                    s[first].a[i]=-1;
                    s[first].cnt--;//记下数组中distinct的数的个数
                }
            }
            s[first].sort_flag=true;//已经排序了
        }         if(!s[second].sort_flag){
            sort(s[second].a,s[second].a+s[second].length);
            for(int i=s[second].length-1;i>=1;i--){
                if(s[second].a[i]==s[second].a[i-1]){
                    s[second].a[i]=-1;
                    s[second].cnt--;
                }
            }
            s[second].sort_flag=true;
        }
        int distinct=0;
        int i=0,j=0;
        while(i<s[first].length&&j<s[second].length){
            if(s[first].a[i]!=-1&&s[second].a[j]!=-1){
                if(s[first].a[i]<s[second].a[j]){
                    distinct++;
                    i++;
                }
                else if(s[first].a[i]>s[second].a[j]){
                    distinct++;
                    j++;
                }
                else{
                    i++;
                    j++;
                }
            }else{
                if(s[first].a[i]==-1&&s[second].a[j]!=-1){
                    i++;
                }else if(s[first].a[i]!=-1&&s[second].a[j]==-1){
                    j++;
                }
                else /*if(s[first].a[i]!=-1&&s[second].a[j]!=-1)*/{//用else if会超时
                    i++;
                    j++;
                }
            }
        }
        while(i<s[first].length){
            if(s[first].a[i]!=-1)
                distinct++;
            i++;
        }
        while(j<s[second].length){
           if(s[second].a[j]!=-1)
                distinct++;
            j++;
        }         long common = (s[first].cnt+s[second].cnt-distinct)/2;
        printf("%.1f%\n",(common*100.0/(common+distinct)));
    }
    return 0;
}


1063. Set Similarity (25)的更多相关文章

  1. PAT 甲级 1063 Set Similarity (25 分) (新学,set的使用,printf 输出%,要%%)

    1063 Set Similarity (25 分)   Given two sets of integers, the similarity of the sets is defined to be ...

  2. 【PAT】1063. Set Similarity (25) 待改进

    Given two sets of integers, the similarity of the sets is defined to be Nc/Nt*100%, where Nc is the ...

  3. 1063 Set Similarity (25分)

    Given two sets of integers, the similarity of the sets is defined to be /, where N​c​​ is the number ...

  4. PAT 1063 Set Similarity (25)

    题意:给你n个集合,k次询问,每次询问求两个集合的(交集)/(并集). 思路:k有2000,集合大小有10000.先将每个集合排序,对每个询问分别设两个指针指向两个集合的头.设a[i]为指针1的值,b ...

  5. PAT (Advanced Level) 1063. Set Similarity (25)

    读入之后先排序. 询问的时候可以o(m)效率得到答案. #include<cstdio> #include<cstring> #include<cmath> #in ...

  6. PAT甲题题解-1063. Set Similarity (25)-set的使用

    题意:两个整数集合,它们的相似度定义为:nc/nt*100%nc为两个集合都有的整数nt为两个集合一共有的整数注意这里的整数都是各不相同的,即重复的不考虑在内.给出n个整数集合,和k个询问,让你输出每 ...

  7. 【PAT甲级】1063 Set Similarity (25 分)

    题意: 输入一个正整数N表示集合的个数(<=50),接着输入N行,每行包括一个数字x代表集合的容量(<=10000),接着输入x个非负整数.输入一个正整数Q(<=2000),接着输入 ...

  8. PAT 1063 Set Similarity[比较]

    1063 Set Similarity (25 分) Given two sets of integers, the similarity of the sets is defined to be N ...

  9. PAT 1063. Set Similarity

    1063. Set Similarity 题目大意 给定 n 个集合, k 个询问, 求任意两个集合的并集和合集. 思路 一道裸的考察 STL 中 set 的题, 我居然还用 hash 错过一遍, 用 ...

随机推荐

  1. 提升 LaTeX 效率的小工具:Detexify LaTeX handwritten symbol recognition

    Detexify LaTeX handwritten symbol recognition 用 LaTeX 的人找符号的表示方法通常很费事,需要去翻长长的列表.Detexify 是一个省事的小网站,只 ...

  2. Java Web 项目获取运行时路径 classpath

    假设资源文件放在maven工程的 src/main/resources 资源文件夹下,源码文件放在 src/main/java/下, 那么java文件夹和resources文件夹在运行时就是class ...

  3. Java中synchronized详解

    synchronized 原则: 尽量避免无谓的同步控制,同步需要系统开销,可能造成死锁 尽量减少锁的粒度 同步方法 public synchronized void printVal(int v) ...

  4. JMockit

    [TOC] 简介 JMockit是基于JavaSE5中的java.lang.instrument包开发,内部使用ASM库来动态修改java的字节码,使得java这种静态语言可以想动态脚本语言一样动态设 ...

  5. How to use Ajax on Visualforce page on Salesforce platform

    Just use Ajax pattern to call object data from server on visualforce page. Following is the Asynchro ...

  6. 对于JSP的调试

    在eclipse中调试JSP 我换了图片但是网页中的图片却不变化 我删了工程里的图片还是没用 看了一下Tomcat根目录..貌似也是没有的.. 最后我考虑换了HTML中图片的名字..并且更改了替换的图 ...

  7. 在C#代码中应用Log4Net(二)典型的使用方式(转)

    不管用什么框架,学什么东西,最初的想法还不是尽快地用上这个框架,所以我们在这个章节还是不打算介绍具体配置节的应用,而是直接给出一个经典的使用样例,让你尽快上手.即使你对Log4Net的配置不熟悉也完全 ...

  8. 试听笔记:技术狂人nodejs

    nodejs概念: 让javascript运行在服务端的开发平台.不是一种语言,不是框架,不是库.特点:单线程异步.事件驱动. PHP.JAVA既是语言也是平台. 创始人:Ryan nodejs cm ...

  9. wpf 背景镂空loading.....

    第一步,,使用arc控件 ArcThickness="15" StartAngle="-6" EndAngle="6" 2,拉一个Ellip ...

  10. Zookeeper 分布式环境搭建

    一.前期环境 安装概览 IP Host Name     Software     192.168.23.128     ae01 JDK 1.7 192.168.23.129 ae02 JDK 1. ...