// 1.九九乘法表

for (var i = 1; i < 10; i++) {
document.write("<span>");
for (var j = 1; j <= i; j++) {
if (j % 2 == 0) {
document.write("<button style='width:60px;background-color: #f2f2f2; '>" + j + "×" + i + "=" + i * j + " " + "</button>");
} else {
document.write("<button style='width:60px;background-color: aqua; '>" + j + "×" + i + "=" + i * j + " " + "</button>");
}
}
document.write("</span>");
document.write("<br>");
}

// 2.使用if判断实现:用户输入年份,判断显示该年是平年还是闰年

var year = Number(prompt("请输入年份"));
if (year > 0&& Number(num) == parseInt(Number(num))) {
if (year % 4 == 0 && year % 100 != 0 || year % 400 == 0) {
alert("闰年");
} else {
alert("平年");
}
} else {
alert("输入错误");
}

// 3.使用for循环实现:请用户输入学生的人数,然后依次输入每一位同学的成绩。 输入完毕之后,将总成绩和平均成绩在控制台输出

var num = prompt("请输入学生人数");
var sum = 0;
if (Number(num) > 0&& Number(num) == parseInt(Number(num))) {
for (var i = 1; i <= num; i++) {
var score = Number(prompt("请输入分数"));
var sum = sum + score;
}
document.write("总成绩:" + sum + "平均成绩:" + sum / num);
} else {
alert("error");
}

// 4.使用while循环实现用户随机输入一个正整数,显示这个正整数各个位数之和

var num = prompt("请输入正整数:");
var i = 0;
var sum = 0;
if (Number(num) > 0 && Number(num) == parseInt(Number(num))) {
while (i <= num.length - 1) {
sum += Number(num[i]);
i++;
}
document.write(sum);
} else {
alert("error");
}

var num = Number(prompt("请输入正整数:"));
var sum = 0;
if (num > 0 && num == parseInt(num)) {
while (num != 0) {
sum += num % 10;
num = parseInt(num / 10);
}
alert("各位数之和:" + sum);
} else {
alert("error");
}

// 5.使用do…while循环实现输出询问:“今天你有认真学习吗?输入yes或no”,如果输入"yes",则弹出"你真是个好孩子!~",如果输入"no",则继续询问

var str = prompt("今天你有认真学习吗?输入yes或no");
if (str !== "yes" && str !== "no") {
alert("error");
} else {
do {
str = prompt("今天你有认真学习吗?输入yes或no");
if (str === "yes") {
alert("你真是个好孩子!~");
break;
}
} while (str === "no");
}

do {
var str = prompt("今天你有认真学习吗?输入yes或no");
if (str === "yes") {
alert("你真是个好孩子!~");
break;
}
} while (1);

// 求数组最大值

var arr = [22, 5, 7, 18, 66];
var max = arr[0];
for (var i = 0; i < arr.length; i++) {
var max = arr[i] >= max ? arr[i] : max;
}
console.log(max);

// 翻转数组

var arr = [22, 5, 7, 'x', 66,33];
for (var i = 0; i < arr.length / 2; i++) {
[arr[i], arr[arr.length - i - 1]] = [arr[arr.length - i - 1], arr[i]];
}
console.log(arr);

// 循环输入存入数组

var arr = [];
var s = prompt("请输入");
while (s !== "" && s !== null) {
arr.push(s);
s = prompt("请输入");
}
console.log(arr);

// 冒泡排序

var arr = [22, 5, 7, 18, 66];
for (var i = 0; i < arr.length; i++) {
for (var j = 0; j < arr.length - i - 1; j++) {
if (arr[j] > arr[j + 1]) {
[arr[j], arr[j + 1]] = [arr[j + 1], arr[j]];
}
}
}
console.log(arr);

// 比较排序

var arr = [22, 5, 7, 18, 66];
for (var i = 0; i < arr.length; i++) {
for (var j = i + 1; j < arr.length - 1; j++) {
if (arr[i] > arr[j]) {
[arr[i], arr[j]] = [arr[j], arr[i]];
}
}
}
console.log(arr);

// 数组去重

var arr = ['a', 'b', 'c', 'a', 'b', 'a'];
var newArr = [];
for (var i = 0; i < arr.length; i++) {
if (newArr.indexOf(arr[i]) === -1) {
newArr.push(arr[i]);
}
}
console.log(newArr);

// 统计个数

var arr = ['a', 'b', 'c', 'a', 'b', 'a'];
var newArr = {};
for (var i = 0; i < arr.length; i++) {
newArr[arr[i]] = (newArr[arr[i]] + 1) || 1;
}
console.log(newArr);

// 去除指定值

var arr = [22, 5, 7, 18, 66];
var carr = [5, 4];
for (var i = 0; i < arr.length; i++) {
for (var j = 0; j < carr.length; j++) {
if (arr[i] == carr[j]) {
arr.splice(i, 1);
i--;
}
}
}
console.log(arr);

// 找出两数组不同元素

var arr1 = [0, 1, 1, 2, 3];
var arr2 = [0, 4, 0];
var newArr = arr1.filter(x => arr2.indexOf(x) == -1).concat(arr2.filter(x => arr1.indexOf(x) == -1));
console.log(newArr);

//此方法只能在两个数组内都没有重复元素时使用
var arr1 = [0, 1, 2, 3, 4, 5];
var arr2 = [0, 4, 6, 1, 3, 9];
var newArr = arr1.concat(arr2).filter(function (v, i, arr) {
return arr.indexOf(v) === arr.lastIndexOf(v);
});
console.log(newArr);

// 多个数组找最大值拼成新数组

var arr1 = [0, 1, 2, 3, 4, 5];
var arr2 = [0, 4, 6, 1, 3, 9];
var array = [arr1, arr2];
var newArr = [];
for (var i in array) {
newArr.push(array[i].sort(function (a, b) {
return b - a;
})[0]);
}
console.log(newArr);

two
1.自定义一个函数,用来实现两个数字的计算,并返回结果

function add(num1, operator, num2) {
return eval(num1 + operator + num2);
}
console.log(add(1, '*', 2));

function computed(num1, operator, num2) {
if (typeof num1 !== 'number' || typeof num2 != 'number') {
return "输入为非数字";
} else {
if (operator == '+') {
return num1 + num2;
} else if (operator == '-') {
return num1 - num2;
} else if (operator == '*') {
returnud num1 * num2;
} else if (operator == '/') {
return num1 / num2;
} else if (operator == '%') {
return num1 % num2;
} else {
return "输入符号错误";
}
}
}
console.log(computed(3, '+', 4));

2.自定义函数,实现数组中join()效果

function myJoin(arr, sign) {
var str = String(arr[0]);
for (var i = 1; i < arr.length; i++) {
str += sign + arr[i];
}
return str;
}
console.log(myJoin([2, 3, 4], ','));

3.自定义函数,实现数组中concat()效果I

function myConcat(arr1, arr2) {
console.log(typeof arr1);
if (typeof arr1 != typeof arr2) {
return "参数类型不一致";
} else if (Array.isArray(arr1)) {
for (var i = 0; i < arr2.length; i++) {
arr1.push(arr2[i]);
}
return arr1;
} else if (typeof arr1 == 'string') {
return arr1 + "" + arr2;
} else {
return "输入不符合要求";
}
}
console.log(myConcat('sdff2234', 'sdfgsd'));

1.打印出100以内的素数
for(var i =2; i <=100; i++){
程序员的思维⽅式,假设型思维
//
我假设这个数就是素数,然后再去判断⼀下,它还能不能被其它数整除
//
如果还有其它数可以整除掉,那么假设就不成⽴了,这个数就不素数了
//
在这⾥给它⼀个标志,⽤于标明这个数就是素数
//
第⼀步:
就代表这个数是素数
//
true
var flag =true;
第⼆步:开始反推,看还有没有其它的数可以被带整除掉
//
for(var j =2; j < i; j++){
if(i % j ==0){
如果这个代码成⽴了,就说明还有其它的数可以整除掉
//
就说明这个数不是素数了
//
i就推翻了之前的假设
//
flag =false;
只要有⼀个数可以被整除就推翻了之前的假设,后⾯的就不⽤再试了
//
所以这个循环就可以结束掉了
//
break;
}
}
如果经过上⾯的反推以后,
仍然是
就说明我们的假设成⽴了
//
flag
true,
if(flag ==true){
console.log(i);
}

}

JavaScript习题之算法设计题的更多相关文章

  1. 数据结构作业——P53页算法设计题(7):原地逆转链表

    一. 题目描述: 设计一个算法,将链表中所有结点的链接方向"原地"逆转,即要求仅利用原表的存储空间,换句话说,要求算法的空间复杂度为O(1). 二.算法设计 #include< ...

  2. 数据结构作业——P53算法设计题(6):设计一个算法,通过一趟遍历确定长度为n的单链表中值最大的结点

    思路: 设单链表首个元素为最大值max 通过遍历元素,与最大值max作比较,将较大值附给max 输出最大值max 算法: /* *title:P53页程序设计第6题 *writer:weiyuexin ...

  3. C算法编程题(四)上三角

    前言 上一篇<C算法编程题(三)画表格> 上几篇说的都是根据要求输出一些字符.图案等,今天就再说一个“上三角”,有点类似于第二篇说的正螺旋,输出的字符少了,但是逻辑稍微复杂了点. 程序描述 ...

  4. javascript数据结构与算法---列表

    javascript数据结构与算法---列表 前言:在日常生活中,人们经常要使用列表,比如我们有时候要去购物时,为了购物时东西要买全,我们可以在去之前,列下要买的东西,这就要用的列表了,或者我们小时候 ...

  5. NOI题库分治算法刷题记录

    今天晚自习机房刷题,有一道题最终WA掉两组,极其不爽,晚上回家补完作业欣然搞定它,特意来写篇博文来记录下 (最想吐槽的是这个叫做分治的分类,里面的题目真的需要分治吗...) 先来说下分治法 分治法的设 ...

  6. 最大子段和的DP算法设计及其效率测试

    表情包形象取自番剧<猫咪日常> 那我也整一个 曾几何时,笔者是个对算法这个概念漠不关心的人,由衷地感觉它就是一种和奥数一样华而不实的存在,即便不使用任何算法的思想我一样能写出能跑的程序 直 ...

  7. 前端开发周报: CSS 布局方式方式与JavaScript数据结构和算法

    前端开发周报:CSS 布局方式与JavaScript动画库 1.常见 CSS 布局方式详见: 一些常见的 CSS 布局方式梳理,涉及 Flex 布局.Grid 布局.圣杯布局.双飞翼布局等.http: ...

  8. 数据结构与算法实验题 6.1 s_sin’s bonus

    数据结构与算法实验题 6.1 s_sin's bonus ★实验任务 正如你所知道的 s_sin 是一个非常贪玩的人 QAQ(如果你非常讨厌他请直接从第二段开 始看),并且令人感到非常遗憾的是,他是一 ...

  9. javascript数据结构与算法 零(前记+前言)

    前记 这本书Data Structure and Algorithm with Javascript 我将其翻译成<< javascript 数据结构和算法>> 为什么这么翻译 ...

  10. JavaScript 数据结构与算法之美 - 十大经典排序算法汇总(图文并茂)

    1. 前言 算法为王. 想学好前端,先练好内功,内功不行,就算招式练的再花哨,终究成不了高手:只有内功深厚者,前端之路才会走得更远. 笔者写的 JavaScript 数据结构与算法之美 系列用的语言是 ...

随机推荐

  1. oeasy教您玩转vim - 31 - # 文字区块

    ​ 文字区块 回忆上节课内容 上上次讲的翻页 上次先让屏幕位置固定,移动光标 H- Head 移动到屏幕的顶端 M- Middle 移动到屏幕的中间 L- Low 移动到屏幕的底部 然后让光标固定,移 ...

  2. C#:利用“事务+乐观锁+version”解决并发下的数据一致性问题

    本文重点介绍通过事务控制,利用数据库的乐观锁和时间戳,来解决并发(非高并发)环境下的脏读.幻读.不可重复读等问题,同时也能解决超卖等现象,对开发企业管理系统的朋友提供一个思路,为更突出主题思路,文涉及 ...

  3. 01-初识springboot

    目录 01,什么是springboot 02,如何使用springboot 01,什么是springboot springboot是一个基于spring框架开发出来的一个新的框架,目的是为了简化spr ...

  4. Django+Bootstrip 卡片模板设计 经典精品

    下面是一个完整的卡片模板代码,包含所有元素,并使用Django的模板语言来处理状态字段的条件渲染.同时还包括示例视图和URL配置. 完整的卡片模板 <div class="card&q ...

  5. golang 学习笔记1

    1.go的gin框架,没有预设目录,具体目录可以在网上参考.

  6. 安卓开发 StateListDrawable 应用

    基础部份     StateListDrawable 安卓开发中,如果要做一个按扭按下改变背景,或获取焦点改变背景,最简单的方法是利用将背景指向一个资源,然后果在资源中配置事件,总共分为三步, 1)  ...

  7. Dubbo日志链路追踪TraceId选型

    一.目的 开发排查系统问题用得最多的手段就是查看系统日志,但是在分布式环境下使用日志定位问题还是比较麻烦,需要借助 全链路追踪ID 把上下文串联起来,本文主要分享基于 Spring Boot + Du ...

  8. 使用update-alternatives管理GCC版本

    目录 简介 操作过程 简介 当操作系统中存在多个版本的GCC时,可以使用使用update-alternatives管理默认使用的编译器版本. 本文使用gcc-9和gcc-11做演示,操作系统为ubun ...

  9. SQL实战从在职到离职(1) 如何处理连续查询

    书接上回,最近离职在家了实在无聊,除了看看考研的书,打打dnf手游,也就只能写写代码,结果昨晚挂在某平台的一个技术出售有人下单了,大概业务是需要帮忙辅导一些面试需要用到的SQL. 回想了下,在该平台接 ...

  10. exceptionx:灵活便捷的Python异常处理库,让异常处理更高效!

    exceptionx English | 中文 exceptionx 是一个灵活且便捷的Python异常处理库,允许你动态创建异常类,并提供多种异常处理机制. exceptionx 的前身是 gqyl ...