软件工程课堂练习找水王续

题目:

随着论坛的发展,管理员发现水王没有了,但是统计结果表明,有三个发帖很多的ID。据统计他们的发帖数量超过了1/4,你能从发帖列表中快速找到他们吗?

 

思路:关联型容器可以很方便解决,php里的array就是关联型数组,php有很多方便的排序函数,所以本次用php实现。

首先对id列表进行遍历,以id为键值对数组$result进行赋值,

如果$result[$id]没有初始化,那么这就是第一次出现,即$result[$id]=1

如果$result[$id]已经初始化,那个发帖数加1,即$result[$id]++

 

最后最$result数组的值降序排序,取出前三个元素就是三个小水王。

 

先开始用的sort,未发觉键名都改了,然后看了一下手册:

Note: 此函数为 array 中的元素赋与新的键名。这将删除原有的键名,而不是仅仅将键名重新排序。

此处介绍一下php的排序函数:

  sort() 函数用于对数组单元从低到高进行排序。
  rsort() 函数用于对数组单元从高到低进行排序。
  asort() 函数用于对数组单元从低到高进行排序并保持索引关系。
  arsort() 函数用于对数组单元从高到低进行排序并保持索引关系。
  ksort() 函数用于对数组单元按照键名从低到高进行排序。
  krsort() 函数用于对数组单元按照键名从高到低进行排序。

 

 

 1 <?php
 2 $idlist = array(1,1,2,2,3,3,4);  //id 列表
 3 
 4 function validate($list)
 5 {
 6     $result=array();
 7     foreach ($list as $v)
 8     {
 9         if(!isset($result[$v]))   //第一次出现 ,赋初始发帖数为1
10         {
11             $result[$v] = 1;
12         }else                     //再次出现 ,发帖数+1
13         {
14             $result[$v]++;
15         }
16     }
17     if(arsort($result))  //对每个id按发帖数降序排列
18     {
19         reset($result);
20         next($result);
21         next($result);
22         if(current($result) < (count($list)/4))  //确认三个小水王的发帖数都大于总帖数的1/4
23         {
24             die('ID list 非法!');
25         }
26     }
27     reset($result);
28     echo key($result) . '<br >';
29     next($result);
30     echo key($result) . '<br >';
31     next($result);
32     echo key($result) . '<br >';
33 }
34 
35 validate($idlist);
36 
37 ?>

 

第一次插入新键时时间复杂度是O(n)

查找时时间复杂度是O(1)

排序用的是快排 O(nlogn)~(n^s)  1<s<2

 

时间上应该慢一些

 

posted @ 2016-05-24 10:57  _Just  阅读(239)  评论(0编辑  收藏  举报