zoukankan      html  css  js  c++  java
  • 一道冒泡排序的算法面试题

    转于:http://www.nowamagic.net/php/php_GetBubble.php

    一道PHP笔试题:请使用伪语言结合数据结构冒泡排序法对以下一组数据进行排序 10 2 36 14 10 25 23 85 99 45。

    关于冒泡排序大家应该都非常熟悉了,原理就不多说了,这里只做简单记录。下面是参考代码。

    <?php
    class engage
    {
        public function getArray()
        {
            $arr1 = array (
    			'0' => array ('fid' => 1, 'tid' => 1, 'name' => 'Name1' ),
    			'1' => array ('fid' => 1, 'tid' => 2 , 'name' => 'Name2' ),
    			'2' => array ('fid' => 1, 'tid' => 5 , 'name' => 'Name3' ),
    			'3' => array ('fid' => 1, 'tid' => 7 , 'name' => 'Name4' ),
    			'4' => array ('fid' => 3, 'tid' => 9, 'name' => 'Name5' )
            );
            $arr2 = array();
            foreach ($arr1 as $key => $value)
            {
                $arr2[$value['fid']][] = array('tid' => $value['tid'],'name' => $value['name']);
            }
            return $arr2;
        }
        //print_r($arr2);
        //$eString = 'open_door';
        public function getString($eString = null)
        {
            $eString = explode('_',$eString);
            $eString = array_map("ucfirst",$eString);
            $eString = implode($eString,'');
            return  $eString;
        }
        /**
         * 冒泡排序 
         * @return unknown
         */
        public function getBubble()
        {
            $isOver = false;
            $bubbleArray =  array(10,2,36,14,10,25,23,85,99,45);
            $bubbleResult = $bubbleArray;
            do{
                $bubbleArray = $bubbleResult;
                $isOver = true;
                foreach ($bubbleArray as $key => $value)
                {
                    if ($value < $bubbleResult[$key-1])
                    {
                        $bubbleResult[$key]=$bubbleResult[$key-1];
                        $bubbleResult[$key-1]=$value;
                        $isOver = false;
                    }
                }
            }while (!$isOver);
            return $bubbleResult;
        }
    
    }
    
    $engage = new engage();
    echo '<pre>';
    print_r($engage->getArray());
    echo '</pre>';
    
    echo $engage->getString('make_by_nowamagic');
    echo '<pre>';
    print_r($engage->getBubble());
    echo '</pre>';
    ?>
    

      程序运行结果如下:

    Array
    (
        [1] => Array
            (
                [0] => Array
                    (
                        [tid] => 1
                        [name] => Name1
                    )
    
                [1] => Array
                    (
                        [tid] => 2
                        [name] => Name2
                    )
    
                [2] => Array
                    (
                        [tid] => 5
                        [name] => Name3
                    )
    
                [3] => Array
                    (
                        [tid] => 7
                        [name] => Name4
                    )
    
            )
    
        [3] => Array
            (
                [0] => Array
                    (
                        [tid] => 9
                        [name] => Name5
                    )
    
            )
    
    )
    MakeByNowamagic
    Array
    (
        [0] => 2
        [1] => 10
        [2] => 10
        [3] => 14
        [4] => 23
        [5] => 25
        [6] => 36
        [7] => 45
        [8] => 85
        [9] => 99
    )
    

      

  • 相关阅读:
    使用内部单向链表实现的一个简单堆栈
    通过反射调用内部类的隐藏方法
    动态代理生成空对象
    通过使用java.lang.reflect.Proxy实现动态代理
    简单代理模式
    暗色CSS,适用与Stylish, IE, FF, OPERA等.
    CWnd派生的控件处理MouseMove, MouseHover, MouseLeave
    _tcscpy_s的size应至少为src的长度+1(要把计算在内)
    用INET(CHttpFile)下载有重定向链接时获取最终URL的方法.
    GetDlgItem以及其他获得CWnd相关的函数要注意。。
  • 原文地址:https://www.cnblogs.com/Alight/p/3411617.html
Copyright © 2011-2022 走看看