1. /*=====================================
  2. 距离排序
  3. 总时间限制: 1000ms 内存限制: 65536kB
  4. 描述
  5. 给出三维空间中的n个点(不超过10个),求出n个点两两之间的距离,并按距离由大到小依次输出两个点的坐标及它们之间的距离。
  6. 输入
  7. 输入包括两行,第一行包含一个整数n表示点的个数,第二行包含每个点的坐标(坐标都是整数)。点的坐标的范围是0到100,输入数据中不存在坐标相同的点。
  8. 输出
  9. 对于大小为n的输入数据,输出n*(n-1)/2行格式如下的距离信息:
  10. (x1,y1,z1)-(x2,y2,z2)=距离
  11. 其中距离保留到数点后面2位。
  12. (用cout输出时保留到小数点后2位的方法:cout<<fixed<<setprecision(2)<<x)
  13. 样例输入
  14. 4
  15. 0 0 0 1 0 0 1 1 0 1 1 1
  16. 样例输出
  17. (0,0,0)-(1,1,1)=1.73
  18. (0,0,0)-(1,1,0)=1.41
  19. (1,0,0)-(1,1,1)=1.41
  20. (0,0,0)-(1,0,0)=1.00
  21. (1,0,0)-(1,1,0)=1.00
  22. (1,1,0)-(1,1,1)=1.00
  23. 提示
  24. 用cout输出时保留到小数点后2位的方法:cout<<fixed<<setprecision(2)<<x
  25.  
  26. 注意:
  27. 冒泡排序满足下面的性质,选择排序和快速排序(qsort或sort)需要对下面的情况进行额外处理
  28. 使用冒泡排序时要注意边界情况的处理,保证比较的两个数都在数组范围内
  29.  
  30. 1. 对于一行输出中的两个点(x1,y1,z1)和(x2,y2,z2),点(x1,y1,z1)在输入数据中应出现在点(x2,y2,z2)的前面。
  31.  
  32. 比如输入:
  33. 2
  34. 0 0 0 1 1 1
  35. 输出是:
  36. (0,0,0)-(1,1,1)=1.73
  37. 但是如果输入:
  38. 2
  39. 1 1 1 0 0 0
  40. 输出应该是:
  41. (1,1,1)-(0,0,0)=1.73
  42.  
  43. 2. 如果有两对点p1,p2和p3,p4的距离相同,则先输出在输入数据中靠前的点对。
  44.  
  45. 比如输入:
  46. 3
  47. 0 0 0 0 0 1 0 0 2
  48. 输出是:
  49. (0,0,0)-(0,0,2)=2.00
  50. (0,0,0)-(0,0,1)=1.00
  51. (0,0,1)-(0,0,2)=1.00
  52. 如果输入变成:
  53. 3
  54. 0 0 2 0 0 1 0 0 0
  55. 则输出应该是:
  56. (0,0,2)-(0,0,0)=2.00
  57. (0,0,2)-(0,0,1)=1.00
  58. (0,0,1)-(0,0,0)=1.00
  59. ======================================*/
  1. #include<iostream>
  2. #include<cmath>
  3. #include <iomanip>
  4. using namespace std;
  5. struct dian
  6. {
  7. int xx,yy,zz;
  8. };
  9. struct juLi
  10. {
  11. dian a,b;
  12. double len;
  13. };
  14. int main()
  15. {
  16. struct dian A[];
  17. struct juLi B[],TEMP;
  18. int n,i,j,t;
  19. int flag;
  20. freopen("4.in","r",stdin);
  21. cin>>n;
  22. for(i=;i<n;i++)
  23. {
  24. cin>>A[i].xx>>A[i].yy>>A[i].zz;
  25. }
  26. t=;
  27. for(i=;i<n-;i++)
  28. {
  29. for(j=i+;j<n;j++)
  30. {
  31. B[t].a=A[i];
  32. B[t].b=A[j];
  33. B[t].len=sqrt((B[t].a.xx-B[t].b.xx)*(B[t].a.xx-B[t].b.xx)+
  34. (B[t].a.yy-B[t].b.yy)*(B[t].a.yy-B[t].b.yy)+
  35. (B[t].a.zz-B[t].b.zz)*(B[t].a.zz-B[t].b.zz));
  36. t++;
  37. }
  38. }
  39.  
  40. for(i=;i<t;i++)
  41. {
  42. flag=;
  43. for(j=;j<t-i;j++)
  44. {
  45. if(B[j].len<B[j+].len)
  46. {
  47. flag=;
  48. TEMP=B[j];
  49. B[j]=B[j+];
  50. B[j+]=TEMP;
  51. }
  52. }
  53. if(flag) break; //if(flag==1) break;
  54. }
  55.  
  56. for(i=;i<t;i++)
  57. {
  58. cout<<'('<<B[i].a.xx<<','<<B[i].a.yy<<','<<B[i].a.zz<<')';
  59. cout<<'-';
  60. cout<<'('<<B[i].b.xx<<','<<B[i].b.yy<<','<<B[i].b.zz<<')';
  61. cout<<'=';
  62. cout<<setiosflags(ios::fixed)<<setprecision()<<B[i].len<<endl;
  63. }
  64. return ;
  65. }

OpenJudge-计算点的距离并排序的更多相关文章

  1. OpenJudge数据结构与算法-计算点的距离并排序

    /*================================================================== 距离排序 总时间限制: 1000ms 内存限制: 65536k ...

  2. 【solr】之solr界面查询返回距离并排序

    使用solr界面查询 {!geofilt}距离函数 star:[4 TO 5]星级排序 geodist() desc 距离排序 pt :31.221717,121.580891 sfield:loca ...

  3. OpenJudge计算概论-整数奇偶排序

    /*===================================== 整数奇偶排序 总时间限制: 1000ms 内存限制: 65536kB 描述 输入10个整数,彼此以空格分隔 重新排序以后 ...

  4. tp5 根据经纬度计算门店距离 可排序

    $branchInfo=Db::name('Branch')->where('b_id','250')->find(); $map['p.cate_id']=array('eq',5); ...

  5. php mysql 根据经纬度计算距离和排序

    #.两点距离(1.4142135623730951) ,),point(,)); ORDER BY distance; mysql 5.6 添加 #.两点球面距离(.0357231545m) ,),p ...

  6. PHP,Mysql根据经纬度计算距离并排序

    网上给出的计算公式是这样的: Lng1表示A点纬度和经度,Lat2 Lng2 表示B点纬度和经度 a = Lat1 – Lat2为两点纬度之差 b = Lng1 -Lng2 为两点经度之差 6378. ...

  7. mysql5.6 的st_distance 实现按照距离远近排序。

    当前所处在的位置(113.858202 , 22.583819 ),需要查询我附近1000米内的小区,并安装由近到远的顺序排列  SELECT s.id,s.name,s.lng,s.lat, rou ...

  8. 利用mysql5.6 的st_distance 实现按照距离远近排序。 (转载)

    http://blog.csdn.net/zhouzhiwengang/article/details/53612481

  9. php根据经纬度排序,根据经纬度筛选距离段

    SQL 语句:select location.* from (select *,round(6378.138*2*asin(sqrt(pow(sin( (36.668530*pi()/180-px_l ...

随机推荐

  1. Redirect HTTP to HTTPS on Tomcat

    I have bought my SSL secure certificate and successfully installed on Tomcat with the keytool but ho ...

  2. C++类的运用 和 三大函数

    在<数据结构与算法分析C++描述>一书中给出了三段代码,简单描述了C++类的接口.实现.与调用: #ifndef INTCELL_H_INCLUDED #define INTCELL_H_ ...

  3. HttpWebRequest 和HttpWebResponse总结

    1. 总结 总结2 3. Code using System; using System.Collections.Generic; using System.Linq; using System.Te ...

  4. EnterpriseLibrary4 自己封装程序集实现log打印

      注意:1)要引用响应的程序集,必须是41的          2)配置文件 using Microsoft.Practices.EnterpriseLibrary.Common.Configura ...

  5. 一个比较完整的Inno Setup 安装脚本

    一个比较完整的Inno Setup 安装脚本,增加了对ini文件设置的功能,一个安装包常用的功能都具备了. [Setup] ; 注: AppId的值为单独标识该应用程序. ; 不要为其他安装程序使用相 ...

  6. PHP header() 函数详细说明(301、404等错误设置)

    原文来自:http://www.veryhuo.com/a/view/41466.html 如果您刚刚开始学习PHP,可能有许多函数需要研究,今天我们就来学习一下PHP Header()的使用方法,更 ...

  7. 【题解】【BT】【Leetcode】Populating Next Right Pointers in Each Node

    Given a binary tree struct TreeLinkNode { TreeLinkNode *left; TreeLinkNode *right; TreeLinkNode *nex ...

  8. 高手C++学习忠告~~[转载]

    1.把C++当成一门新的语言学习(和C没啥关系!真的.): 2.看<Thinking In C++>,不要看<C++变成死相>: 3.看<The C++ Programm ...

  9. 常见的XMLHttpRequest.status状态码

    XMLHttpRequest.status状态码 1xx-信息提示 这些状态代码表示临时的响应.客户端在收到常规响应之前,应准备接收一个或多个1xx响应. 100-继续. 101-切换协议. 2xx- ...

  10. Customize R initiallization in Mac

    First, we need to find a "Rprofile" document. locate Rprofile Then we find Rprofile docume ...