当作为一名php 程序猿,每天总与数据库打交道,做着最底层的程序猿的工作,開始着手研究一些算法,希望自己能在计算机的道路上走的更远。事实上我更喜欢管理,希望自己能作为一个卓越的管理者,但并不影响我对技术的追求。

*

***

   *****

  *******

 *********

***********

上图php代码例如以下

<?php
for($i=1;$i<=6;$i++){
for($z=5;$z>=$i;$z--){
echo " ";
}
for($j=1;$j<=2*$i-1;$j++){
echo "*";
}
echo "<br/>";
}

二.用PHP 写杨辉三角。

1   

                  1   1   

                1   2   1   

              1   3   3   1   

            1   4   6   4   1   

          1   5   10   10   5   1   

        1   6   15   20   15   6   1   

      1   7   21   35   35   21   7   1   

    1   8   28   56   70   56   28   8   1   

  1   9   36   84   126   126   84   36   9   1

如上图 :

<?php
for($i = 0; $i < 10; $i ++) {
for($z = 9; $z >= $i; $z --) {
echo "  ";
}
for($j = 0; $j <= $i; $j ++) {
if($j==0 || $j==$i){
$newarray[$i][$j]=1;
}else{
$newarray[$i][$j]=$newarray[$i-1][$j]+$newarray[$i-1][$j-1];
}
echo $newarray[$i][$j]."   ";
} echo "<br/>";
}

简单思路:

1.首先杨辉三角初始模型应该例如以下图

1   

                   1      1   

                1     1     1   

              1   1   1   1   

            1   1   1   1   1   

          1  1    1    1   1   1   

        1   1  1   1   1   1   1   

      1   1   1   1   1    1  1   1   

    1   1   1   1   1   1   1   1   1   

  1   1   1   1   1   1   1   1   1   1

上图的形式应该非常好表示的,依据菱形的特定去考虑。两个for 循环就搞定了。

由由于向数组,把它存在数组里,在显示出来,就能够了。

<?php
/**
* @author lxy
* 在一组数中,要求插入一个数,按其原来顺序插入,维护原来排序方式。
* 首先须要说明的是用户给定的数组是要有一定顺序的。如升序或降序
* 不能用排序函数如sort等
*/
class insertvalue {
private function __construct() {
}
/**
* 推断是升序还是降序
* 由于数组是有顺序的所以能够这样处理
* 可是要保证键名必须从 0 開始
* 保证数组数据没有反复的值,
*/
private static function judgesort($array) {
$flg = '';
$countarray = count ( $array );
$newarray = array_unique ( $array );
$newarray = array_values ( $newarray ); // 保证键值都是从0,1,2開始的
$n = count ( $newarray );
if (count ( $newarray ) == 1) {
$flg = 0;
} else {
for($i = 0; $i < $n; $i ++) {
if ($newarray [$i] < $newarray [$i + 1]) {
$flg = 1;
break;
} else {
$flg = - 1;
break;
}
}
}
return $flg;
}
/**
* 插入元素
*/
private static function insertvalue($val, $array) {
$flg = self::judgesort ( $array );
$n = count ( $array );
// 升序
if ($flg == 1) { if ($val > $array [count ( $array ) - 1]) {
$array [count ( $array ) + 1] = $val;
return $array;
}
for($i = 0; $i < $n; $i ++) {
if ($array [$i] >= $val) {
$t1 = $array [$i];
$array [$i] = $val;
for($j = $i + 1; $j <= $n; $j ++) {
$t2 = $array [$j];
$array [$j] = $t1;
$t1 = $t2;
}
return $array;
}
}
}
// 降序
if ($flg == - 1) {
if ($val <= $array [$n - 1]) {
$array [$n] = $val;
return $array;
}
for($i = 0; $i < $n; $i ++) {
if ($val >= $array [$i]) {
$t3 = $array [$i];
$array [$i] = $val;
for($j = $i + 1; $j <= $n; $j ++) {
$t4 = $array [$j];
$array [$j] = $t3;
$t3 = $t4;
}
return $array;
}
}
}
if ($flg == 0) {
$array [$n] = $val;
return $array;
}
}
/**
* 入口文件
*/
public static function main($val, $array) {
$newarray = insertvalue::insertvalue ( $val, $array );
return $newarray;
}
} $a = 6;
$array = array (
1,
1,
1,
1,
1,
9
);
$newarray = insertvalue::main ( $a, $array );
var_dump ( $newarray );
<?php
/**
*通过hash 比較两个数组同样的数
*/
$arr=array(a,b,c,d,f);
$towarr=array(a,c,d);
$same=array();
$newarray=array();
foreach($arr as $val){
$newarray[$val]=1;
}
foreach ($towarr as $value){
if($newarray[$value]==1){
$same[]=$value;
}
}
<?php
/**
* 合并多个数组,不用array_merge(),题目来于论坛。
*/
header("Content-type:text/html;charset='utf-8'");
function conjunctionarray() {
$newarray = array ();
$num = func_num_args (); //函数參数的个数
$valarray = func_get_args (); //參数列表
for($i = 0; $i < $num; $i ++) {
if (is_array ( $valarray [$i] )) {
$newarray [] = $valarray [$i];
} else {
exit ( $valarray [$i] . '不是数组' );
}
}
return $newarray;
} $a = array (
1,
2,
3
);
$b = array(3);
print_r ( conjunctionarray ( $a, $b ) );

php 基础算法(用*表示金字塔)通过hash 比較两个数组同样的数的更多相关文章

  1. 10个经典的C语言面试基础算法及代码

    10个经典的C语言面试基础算法及代码作者:码农网 – 小峰 原文地址:http://www.codeceo.com/article/10-c-interview-algorithm.html 算法是一 ...

  2. 海量数据挖掘MMDS week2: 频繁项集挖掘 Apriori算法的改进:基于hash的方法

    http://blog.csdn.net/pipisorry/article/details/48901217 海量数据挖掘Mining Massive Datasets(MMDs) -Jure Le ...

  3. C语言的10大基础算法

    C语言的10大基础算法 算法是一个程序和软件的灵魂,作为一名优秀的程序员,只有对一些基础的算法有着全面的掌握,才会在设计程序和编写代码的过程中显得得心应手.本文包括了经典的Fibonacci数列.简易 ...

  4. PHP基础算法

    1.首先来画个菱形玩玩,很多人学C时在书上都画过,咱们用PHP画下,画了一半. 思路:多少行for一次,然后在里面空格和星号for一次. <?php for($i=0;$i<=3;$i++ ...

  5. Java基础算法集50题

    最近因为要准备实习,还有一个蓝桥杯的编程比赛,所以准备加强一下算法这块,然后百度了一下java基础算法,看到的都是那50套题,那就花了差不多三个晚自习的时间吧,大体看了一遍,做了其中的27道题,有一些 ...

  6. 海量数据挖掘MMDS week2: 频繁项集挖掘 Apriori算法的改进:非hash方法

    http://blog.csdn.net/pipisorry/article/details/48914067 海量数据挖掘Mining Massive Datasets(MMDs) -Jure Le ...

  7. 贝叶斯公式由浅入深大讲解—AI基础算法入门

    1 贝叶斯方法 长久以来,人们对一件事情发生或不发生的概率,只有固定的0和1,即要么发生,要么不发生,从来不会去考虑某件事情发生的概率有多大,不发生的概率又是多大.而且概率虽然未知,但最起码是一个确定 ...

  8. python_基础算法

    本篇主要实现九(八)大排序算法,分别是冒泡排序,插入排序,选择排序,希尔排序,归并排序,快速排序,堆排序,计数排序.希望大家回顾知识的时候也能从我的这篇文章得到帮助. 概述 十种常见排序算法可以分为两 ...

  9. 贝叶斯公式由浅入深大讲解—AI基础算法入门【转】

    本文转载自:https://www.cnblogs.com/zhoulujun/p/8893393.html 1 贝叶斯方法 长久以来,人们对一件事情发生或不发生的概率,只有固定的0和1,即要么发生, ...

随机推荐

  1. Tomcat—怎样在Tomcat Webserver下部署Web项目

            总结一下怎样在Tomcat Webserver下部署Web项目:

  2. SqlServer 添加列并赋值

    有个需求,需要给某张表添加一列并且赋值,分解需求,一共分两部走: 添加列 赋值 两个功能都不难,很快实现. --add column alter table Med_Summary_Template ...

  3. vijos 1234 口袋的天空

    最小生成树kruscal算法 #include<iostream> #include<algorithm> #include<cstring> #define ma ...

  4. BZOJ 1009 HNOI2008 GT考试 KMP算法+矩阵乘法

    标题效果:给定的长度m数字字符串s.求不包括子s长度n数字串的数目 n<=10^9 看这个O(n)它与 我们不认为这 令f[i][j]长度i号码的最后的字符串j位和s前者j数字匹配方案 例如,当 ...

  5. JAVA多线程两个实用的辅助类(CountDownLatch和AtomicBoolean)

    AtomicBoolean它允许一个线程等待一个线程完成任务,然后运行: A boolean value that may be updated atomically. See the java.ut ...

  6. 华夏互联与逐浪CMS旗下三款软件获著作权登记

     北京时间2014年7月24日消息: 上海逐一软件科技公司长下三款软件通过中国知识产权局登记,当中包含全新的CMS2 x2.0主产品.移动门户管理系统.云台管理系统. 除主产品CMS2 x2.0( ...

  7. hdoj 1506&amp;&amp;1505(City Game) dp

    // l表示从l[i]到i连续大于a[i]的最远左区间.r表示从i到r[i]连续大于a[i]的最远又区间 DP 找出 a[i] 的最远左区间和最远右区间与自己连着的比自己大的数的长度 , 然后用这个长 ...

  8. Unity 4.5.2 for Mac 下载+安装+破解

    因为课程须要, 须要安装unity, 就捣腾了一下, 顺便Mark. 须要准备的资源: Unity 4.5.2官方安装包 : http://netstorage.unity3d.com/unity/u ...

  9. 脚本+批处理打造IIS监控器

    原文 脚本+批处理打造IIS监控器 首先说下我什么要写它,第一.它可以帮你做一件事,那就是随时给你监控你公司的网站服务器的状态,一旦你的网站出现问题不能访问了,它就会自动帮你重启IIS然后让死掉的网站 ...

  10. 每天收获一点点------Hadoop基本介绍与安装配置

    一.Hadoop的发展历史 说到Hadoop的起源,不得不说到一个传奇的IT公司—全球IT技术的引领者Google.Google(自称)为云计算概念的提出者,在自身多年的搜索引擎业务中构建了突破性的G ...