zoukankan      html  css  js  c++  java
  • 【Floyd】珍珠

      【题目描述】

    有n颗形状和大小都一致的珍珠,它们的重量都不相同。n为整数,所有的珍珠从1到n编号。你的任务是发现哪颗珍珠的重量刚好处于正中间,即在所有珍珠的重量中,该珍珠的重量列(n+1)/2位。下面给出将一对珍珠进行比较的办法:

    给你一架天平用来比较珍珠的重量,我们可以比出两个珍珠哪个更重一些,在作出一系列的比较后,我们可以将某些肯定不具备中间重量的珍珠拿走。

    例如,下列给出对5颗珍珠进行四次比较的情况:

    1、珍珠2比珍珠1重

    2、珍珠4比珍珠3重

    3、珍珠5比珍珠1重

    4、珍珠4比珍珠2重

    根据以上结果,虽然我们不能精确地找出哪个珍珠具有中间重量,但我们可以肯定珍珠1和珍珠4不可能具有中间重量,因为珍珠2、4、5比珍珠1重,而珍珠1、2、3比珍珠4轻,所以我们可以移走这两颗珍珠。

    写一个程序统计出共有多少颗珍珠肯定不会是中间重量。

       【输入】

    第一行包含两个用空格隔开的整数N和M,其中1≤N≤99,且N为奇数,M表示对珍珠进行的比较次数,接下来的M行每行包含两个用空格隔开的整数x和y,表示珍珠x比珍珠y重。

       【输出】

    一行包含一个整数,表示不可能是中间重量的珍珠的总数。

       【样例输入】

    5 4
    2 1
    4 3
    5 1
    4 2
    【样例输出】
    2
    看完题目没思路?其实超简单
    弗洛伊德轻松搞定!!!
    其实如果有(n+1)/2个珍珠比一个珍珠重,那么这个珍珠一定不在中间。
    AC代码如下
     1 #include<iostream>
     2 #include<cstring>
     3 #include<string>
     4 #include<cstdio>
     5 #define N 1001
     6 using namespace std;
     7 int heavy[N][N], light[N][N];
     8 int n, m, ans=0;
     9 int main()
    10 {
    11     cin>>n>>m; 
    12     int a, b;
    13     for (int i=1; i<=m; i++){
    14         cin>>a>>b;
    15         heavy[a][b]=1;
    16         light[b][a]=1;
    17     }
    18     for (int k=1; k<=n; k++)
    19         for (int i=1; i<=n; i++)
    20             for (int j=1; j<=n; j++)
    21                 if(i!=j && i!=k && j!=k){
    22                     heavy[i][j]=heavy[i][j] || (heavy[i][k] && heavy[k][j]);    //如果i比k重且k比j重,那么i比j重 
    23                     light[i][j]=light[i][j] || (light[i][k] && light[k][j]);
    24                 }
    25     for (int i=1; i<=n; i++){
    26         a=0;b=0;
    27         for(int j=1; j<=n; j++){
    28             if(heavy[i][j])
    29                 a++;
    30             else if(light[i][j])
    31                 b++;
    32         }
    33         if(a>=(n+1)/2 || b>=(n+1)/2) ans++;
    34     }
    35     cout<<ans<<endl;
    36     return 0;
    37 }
     
  • 相关阅读:
    关于python的open函数encoding的入参
    控制台输出的log加颜色
    logging把log写到控制台
    合并两个list里的字典
    关于字典数组和元组合并
    python字典做入参调用时要写成**K这种形式
    python在循环中将含变量的字典加到列表中(问题:如果写法不当,会导致最后赋值的变量覆盖列表中前面赋值的变量)
    给定列表,按照列表内容获取excel指定列名下的内容
    selenum报错element is not attached to the page document
    python selenium获取input输入框中的值
  • 原文地址:https://www.cnblogs.com/Alan-Anders/p/10326711.html
Copyright © 2011-2022 走看看