IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> JS算法(日常练习) -> 正文阅读

[游戏开发]JS算法(日常练习)

js算法(日常练习)

返回最长重复字符串

function tp21(i){
        
        var arr=i.split('');//将字符串分隔
        var num=0;//计数器,用来比较重复字符串长度
        var maxstr1='';
        var maxstr2='';//如果有2个相同字符串用来存放
        var a;
        a=arr[0]//赋初值
        var strend;
        for(var i=0;i<arr.length;i++){
            if(arr[i]==a){
                num++;//如果匹配到相同字符,计数器加一
            }
            else{
                strend=i;//重置结束位置,即从不相同的字符开始匹配
                maxstr2=arr.slice(strend-num,strend);//一个新字符串
                if(maxstr2.length>maxstr1.length){
                    maxstr1=maxstr2;//小换大
                }
                a=arr[i];
                num=1;//重置计数器
            }
        }
        if(maxstr2.length==0){
            console.log('最长长度0')
        }
        else{
            console.log(maxstr2);
        
        }

    }

首字母大写

 function tp26(str){
        
        //切割字符串
        var arr = str.split(' ');
        // console.log(arr);
        for(var i = 0;i<arr.length;i++){
            //将首字母大写 拼接后面没有首字母的部分
            arr[i]=arr[i].charAt(0).toUpperCase()+arr[i].slice(1);
            //返回arr[i]开头的位置大写,然后加上后面
    }
    //将数组转为字符串
    console.log(arr.join(' '));
}

冒泡排序

//let arr = [8,4,5,9,12,6,7]
function maopao(arr){
	for(var i=0;i<arr.length-1;i++){
		
		for(var j=0;j<arr.length-i-1;j++){
			
			if(arr[j]>arr[j+1]){
				var temp = arr[j];
				arr[j] = arr[j+1]
				arr[j+1] = temp;
				
			}
			
		}
		
	}
	
	console.log(arr);//[4,5,6,7,8,9,12]
}

生成完全二叉树

function isCompleteTree(root)
{
	if(!root)
		return true;
	var flag = 0;
	var queue = [];
	queue.push(root);
	while(queue.length != 0)
	{
		var node = queue.shift();

		if(!node.left)
    		flag = 1;//表示后面不能有节点了
		else if(node.left && flag == 0)
    		queue.push(node.left);
		else if(node.left && flag == 1)
    		return false;

		if(!node.right)
    		flag = 1;
		else if(node.right && flag == 0)
    		que.push(node.right);
		else if(node.right && flag == 1)
    		return false;
	}
	return true;
}

判断是否为平衡二叉树

function maxDepthOfTree(node)
{
	if(!node)
		return 0;
	return Math.max(maxDepthOfTree(node.left),maxDepthOfTree(node.right))+1;
}

function isBalanced(node)
{
	if(!node)
		return true;
	var left = maxDepthOfTree(node.left);
	var right = maxDepthOfTree(node.right);
	if(Math.abs(left-right) > 1)
		return false;
	return isBalanced(node.left) && isBalanced(node.right);
}

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2022-04-18 18:15:32  更:2022-04-18 18:17:13 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 21:14:22-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码