JS算法题 JavaScript常见算法题 基础语法案例(持续更新)2022年3月30日

JS算法题 JavaScript常见算法题 基础语法案例(持续更新)2022年3月30日JavaScript基础案例,用法,算法题

大家好,又见面了,我是你们的朋友全栈君。

JavaScript算法题

提示:更新时间
2022年3月30日14:31:48



提示:以下是本篇文章正文内容,下面案例可供参考

案例

1.九九乘法表

代码如下(示例):

		//99乘法表
		var output = "";
        for (var i = 1; i <= 9; i++) { 
   
            for (var j = 1; j <= i; j++) { 
   
                output += j + "*" + i + "=" + i * j + "\t";
            }
            output += "\n";
        }
        console.log(output);

效果图
在这里插入图片描述


2.最大公约数

代码如下(示例):

		// 两个数的最大公约数
        var a = prompt("请输入第一个数");
        var b = prompt("请输入第二个数");
        var max;
        (a > b) ? max = a : max = b;
        for (var i = max; i > 0; i--) { 
   
            if (a % i == 0 && b % i == 0) { 
   
                console.log(i);
                break;
            }
        }

3.最小公倍数

代码如下(示例):

		// 输入两个数判断最小公倍数
        var a = prompt("请输入第一个数");
        var b = prompt("请输入第二个数");
        for (var i = 1; i <= a * b; i++) { 
   
            if (i % a == 0 && i % b == 0) { 
   
                alert(i);
                break;
            }
        }

4.求整数1~100的累加值,但要求跳过所有个位为3的数

代码如下(示例):

		//求整数1~100的累加值,但要求跳过所有个位为3的数。
		var num = 0;
        for (var i = 1; i <= 100; i++) { 
   
            if(i%10==3){ 
   
                continue;
            }
            num+=i;
            // console.log(i);
        }
        console.log(num);

5.数组去重,去除重复的数字

代码如下(示例):

var arr = [7, 3, 3, 7, 12, 13, 41, 15, 24, 4, 12, 41];
        var newArr = [];
        for (var i = 0; i < arr.length; i++) { 
   
            var bool = true;
            for (var j = 0; j < newArr.length; j++) { 
   
                if (newArr[j] == arr[i]) { 
   
                    bool = false;
                    break;
                }
            }
            if (bool) { 
   
                newArr[newArr.length] = arr[i]
            }
        }
        console.log("原先的数组:"+arr);
        console.log(newArr);

6.数组排列,从小到大

代码如下(示例):

        var arr = [7, 3, 66, 34, 13, 41, 24, 4, 1, 10];
		//一段数组,求出从小到大的排序
        for (var i = 0; i < arr.length - 1; i++) { 
   
            for (var j = 0; j < arr.length - 1 - i; j++) { 
   
                if (arr[j] > arr[j + 1]) { 
   
                    var temp = arr[j];
                    arr[j] = arr[j + 1];
                    arr[j + 1] = temp;
                }
            }
        }
        console.log(arr);

7.数组倒置,顺序置换

代码如下(示例):

		//一段数组,相反排列
        var arr = [7, 3, 66, 34, 13, 41, 24, 4, 1, 10];
        for (var i = 0; i < arr.length - 1; i++) { 
   
            for (var j = 0; j < arr.length - 1 - i; j++) { 
   
                var temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
        console.log(arr);

8.水仙花数,输出100-999的数

代码如下(示例):

 		// 水仙花数, 每个位上的数的 三次方,相加 等于这个数
        var a = 0,//个位
            b = 0,//十位
            c = 0;//百位
        var num = 0;//出现的个数
        for (var i = 100; i <= 999; i++) { 
   
            a = i % 10;
            b = parseInt(i / 10) % 10;
            c = parseInt(i / 100) % 10;
            //parseInt用法,转换为整数,去除小数点后的数

            if (Math.pow(a, 3) + Math.pow(b, 3) + Math.pow(c, 3) == i) { 
   
                num++;
                console.log(i);
            }
        }
        console.log("一共有:" + num);

9.百钱百鸡,一百块钱买一百只鸡,公鸡5块钱一只,母鸡3块钱一只,小鸡1块钱3只

代码如下(示例):

 		//百钱百鸡 公鸡5块 母鸡3块 小鸡 1块3只 一百块买一百只鸡 公鸡母鸡小鸡个多少只
    <script>
        var num = 100;

        for (var i = 1; i < 100; i++) { 
   
            var a = 5 * i;
            for (var j = 1; j < 100; j++) { 
   
                var b = 3 * j;
                //如果需要用后面的方法,从这里把后面的if判定注释掉,然后放出for循环的语句
                var c = 100 - a - b;//多少钱
                if (i + j + c * 3 == 100) { 
   
                    console.log("公鸡:" + i + "只," + "一共要" + a + "块钱");
                    console.log("母鸡:" + j + "只," + "一共要" + b + "块钱");
                    console.log("小鸡:" + c * 3 + "只," + "一共要" + c + "块钱");
                    console.log("--------分割线--------");
                }
                // for (var k = 1; k < 100; k++) { 
   
                // var c = k / 3;
                // if (a + b + c == 100 && i + j + k == 100) { 
   
                // console.log("公鸡:" + i + "只," + "一共要" + a + "块钱");
                // console.log("母鸡:" + j + "只," + "一共要" + b + "块钱");
                // console.log("小鸡:" + k + "只," + "一共要" + c + "块钱");
                // console.log("--------分割线--------");
                // }
                // }
                
            }

        }
    </script>

有两种写法,一种是三个循环,一种是循环两次,然后用100去减,


10.不用第三个变量,交换a和b的值 ( 常见 )

代码如下(示例):

        var a = 18;
        var b = 55;
        a = a + b;
        //得到一个新的a
        console.log("新的a:"+a);
        b = a - b;
        //用新的a减去原来的b,得到的肯定是原来的a,现在赋值给b
        console.log("交换后的b: "+b);
        a = a - b
        //再减去新赋值的b,剩下的a,就是原来的b,现在a和b已经换了位置了
        console.log("交换后的a: "+a);

		//理解就好,不必强记

总结

提示:这里对文章进行总结:
每天持续更新,可以从顶部标题寻找

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/149749.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Enterprise Library 验证的实现

    Enterprise Library 验证的实现参考地址:http://www.cnblogs.com/huangcong/archive/2010/06/03/1749634.htmlEnterpriseLibrary的验证我觉得最大的改变了验证的位置,可以通过配置文件来修改验证规则,这就极大的使验证更加灵活,原文中的一个错误就是第一步让点击 AddDatabaseSettings这个地方错了,应该点击AddSecuritySe…

    2022年10月20日
    0
  • kalman滤波融合原理及其matlab仿真「建议收藏」

    kalman滤波融合原理及其matlab仿真「建议收藏」1、kalman原理卡尔曼滤波是一种递推式滤波方法,不须保存过去的历史信息,新数据结合前一刻已求得的估计值及系统本身的状态方程按一定方式求得新的估计值。1.1、线性卡尔曼假设线性系统状态是k,卡尔曼原理可用以下五个公式表达:X(k|k-1)=AX(k-1|k-1)+BU(k)………..(1)P(k|k-1)=AP(k-1|k-1)A’+Q…………

    2022年5月28日
    44
  • 手机上好用的java编译器_手机上好用的java编译器

    手机上好用的java编译器_手机上好用的java编译器手机上好用的java编译器安卓版是一款专为java开发人员服务的编辑客户端应用,利用手机上好用的java编译器手机安卓版实时进行相关编辑还能进行简单的编译,运行单个小程序等,提供您的效率。功能介绍手机上好用的java编译器安卓版是一款将openjdk中关于编译java工程的代码移植到了安卓平台。手机上好用的java编译器手机安卓版支持添加jar格式的lib文件,并且将编译后的程序dex化,以便在安…

    2022年7月14日
    32
  • mysql报错1396_mysql连接不上数据库

    mysql报错1396_mysql连接不上数据库我似乎无法重新创建一个已删除的简单用户,即使以root用户身份在MySQL中也是如此。我的情况是:用户’jack’曾经存在,但是我从mysql.user中删除了它以重新创建它。我在那张桌子上看不到任何痕迹。如果我对其他随机用户名(例如“jimmy”)执行此命令,则该命令会正常工作(就像最初对“jack”所做的一样)。我已经做了些什么来破坏用户“jack”,以及如何撤销该破坏,以便重新创建“…

    2022年8月12日
    3
  • vue todolist案例_nodejs mvc

    vue todolist案例_nodejs mvc1.应用模板下载:TodoMVC案例官网:http://todomvc.com如图下载模板:2.npm安装依赖通过nmp安装相关依赖,进入vscode,找到文件,右键点击在集成终端中打开,输入命令npmi进行安装;并且安装npmivue@2.6.103.引入Vue.js我们在app.js中编写Vue代码,所以要在app.js前面引入4.数据渲染4.1当任务列表(items)没有数据时,#main和#footer标识的标签应该被..

    2022年9月11日
    0
  • bzero函数C语言_zeros函数

    bzero函数C语言_zeros函数原型:externvoidbzero(void*s,intn);  用法:#include  功能:置字节字符串s的前n个字节为零且包括‘\0’。  说明:bzero无返回值,并且使用strings.h头文件,strings.h曾经是posix标准的一部分,但是在POSIX.1-2001标准里面,这些函数被标记为了遗留函数而不推荐使用。在POSIX.

    2022年10月12日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号