JS练习题2共8题
<p>1 打印出1-100里所有的偶数</p>
<script>
// for(var i=1;i<=100;i++){
// if(i%2==0){
// document.write(i+" ");
// }
// }
</script>
<p>2 打印出1-100里所有的奇数</p>
<script>
// for(var i=1;i<=100;i++){
// if(i%2==1){
// document.write(i+" ");
// }
// }
</script>
<p>3 求出1-1/2+1/3-1/4…..1/100的结果</p>
<script>
// 把所有加减数都看成加数,如把(-1/2)看成+(-1/2)
var j=0; //保存所有加数
for(var i=2;i<=100;i++){ /*加数的分母,从2开始*/
if(i%2==0){ /*如果能是偶数,置为正数,-1/i*/
j+=-1/i; /*把这些数相加并保存起来*/
}else{ /*如果能是偶数,置为负数+1/i*/
j+=+1/i; /*把这些数相加并保存起来*/
}
}
console.log(1+j); /*然后加上所有的加数*/
</script>
<p>4 输出20-80之间能被3整除的整数,每5个一行</p>
<script>
var j=1;/*保存已经获得的个数*/
for(var i=20;i<=80;i++){
if(i%3==0){/*如果i是能被3整除的数*/
document.write(i+" ");就把i输出
if(j%5==0){/*如果是5的倍数,也就是满5个那就输入一个转行*/
document.write("<br>")
}
j++;
}
}
</script>
<p>5 打印出1000-2000年中所有的闰年,并以每行四个数的形式输出(提示:四年一闰,百年不闰,四百再闰)。</p>
<script>
//一
var j=0; /*保存闰个数*/
for(var i=1000;i<=2000;i++){
if((i%100!=0)){ /*不是100年的*/
if(i%4==0){ /*不是100年且是4年的*/
j++;
document.write(i+" ")
if(j%4==0){
document.write("<br>")
}
}
}else{
if(i%400==0){ /*是400年的*/
j++;
document.write(i+" ")
if(j%4==0){
document.write("<br>")
}
}
}
}
//二
var j=0; /*保存闰年个数*/
for(var i=1000;i<=2000;i++){
if((i%4==0&&i%100!=0)||(i%400==0)){ /*能被4整除且不能被100整数,或,能被400整除*/
j++;
document.write(i+" ");
if(j%4==0){ /*如果闰年个数为4个再输出一个转行*/
document.write("<br>");
}
}
}
</script>
<p>6 输入一个数,判断其是否为素数(提示:在大于1的自然数中,除了1和它本身以外不再有其他因数的数)。</p>
<script>
//方法一
document.write('<input id="ipt"><button id="btn">判断</button>');
var ipt=document.getElementById("ipt");
var btn=document.getElementById("btn");
btn.onclick=function(){
var j=0;/*保存因数个数*/
if(!(isNaN(ipt.value))&&!(ipt.value<=1)&&!(ipt.value=="")&&!(ipt.value%1!=0)){//条件分别是:不为非数字、不小于等于1、不为小数
for(var i=1;i<=ipt.value;i++){
if((ipt.value/i)%1==0){ /*如果余数为0,就是因数。 【(ipt.value/i)%1】 可以写成 【(ipt.value)%i】 */
j++;
}
}
if(j==2){ /*如果因数个数最大为2*/
alert("是素数")
}
}else{
alert("请输入大于1的整数")
}
} //方法二,数字4有问题
// document.write('<input id="ipt"><button id="btn">判断</button>');
// var btn=document.getElementById("ipt");
// var btn1=document.getElementById("btn");
// btn1.onclick=function(){
// var number=parseInt(btn.value);
// if(abc(number)){ /*如果abc()返回真才执行*/
// alert(number + "是素数");
// }else{
// alert(number + "不是素数");
// }
// }
// function abc(num){ /*相当于在函数内的声明了变量: var num*/
// if(num==1){ //1不是素数
// return false; //结束函数
// }else{
// for(var i=2;i<Math.sqrt(num);i++){ //如数字10中5(一半)以下的除不尽,5以上也没有能除尽的了。所以开方一下Math.sqrt,以减少循环。
// if(num%i==0){
// return false;
// }
// }
// }
// return true;
// } </script>
<p>7 求100-200之间的素数</p>
<script>
for(var i=100;i<=200;i++){
var k=0; /*保存因数个数*/
for(var j=1;j<=i;j++){ /*除数*/
if((i/j)%1==0){ 如果商没有小数,开始合计因数个数
k++;
}
}
if(k==2){ /*因数总个数为2就是素数*/
document.write(i+" ")
}
}
</script>
<p>8 任给正整数n,计算 1!+2!+3!+ …+n!。(提示:3!=3*2*1)</p>
<script>
document.write('<input id="ipt"><button id="btn">计算</button>');
var ipt=document.getElementById("ipt");
var btn=document.getElementById("btn");
var j=1; /*保存阶乘值*/
var k=0; /*保存阶乘值的和*/
btn.onclick=function(){
if(!(isNaN(ipt.value)) && !(ipt.value%1!=0) && !(ipt.value<1)){
for(var i=1;i<=ipt.value;i++){
j*=i;
k+=j;
}
alert(k)
}else{
alert("请输入大于1的整数")
}
}
</script>
<p>9 求Sn=a+aa+aaa+……+aa……a之值,其中a是一个数字,n是文本框输入的。</p>
<script>
document.write('输入a:<input id="ipt" value>输入n:<input id="ipt2"><button id="btn">计算</button>')
btn.onclick=function(){
var s1=0;
var s2=0;
var a=document.getElementById("ipt");
var n=document.getElementById("ipt2");
var btn=document.getElementById("btn");
if((!(isNaN(n.value)) && !(n.value<1) && !(n.value%1!=0)) && !(isNaN(a.value)) && !(a.value<1) && !(a.value%1!=0)){
for(var i=0;i<=(n.value-1);i++){ /*i是次方*/
s1+=a.value*Math.pow(10,i); /*从低位开始还原数位,如1=1*10^1;10=1*10^2;100=10*10^3;...再把他们相加,也就是s1,合成完整数字。如111*/
s2+=s1; /*把每次合成的值保存在s2中,作为题目中的加数之一*/
}
alert(s2*2-s1);//从题目的式子可以看出,1+11+111+11+1,其中出了111只被加一次其他都加了两次,所以直接把之前计算的s2*2再减去最后合成的一个数s1就可以了。
}else{
alert("请输入大于0的整数")
}
} document.write('输入a:<input id="ipt" value>输入n:<input id="ipt2"><button id="btn">计算</button>')
btn.onclick=function(){
var s1=0;
var s2=0;
var a=document.getElementById("ipt");
var n=document.getElementById("ipt2");
var btn=document.getElementById("btn");
if((!(isNaN(n.value)) && !(n.value<1) && !(n.value%1!=0)) && !(isNaN(a.value)) && !(a.value<1) && !(a.value%1!=0)){
for(var i=0;i<=(n.value-1);i++){ /*i是次方*/
s1+=a.value*Math.pow(10,i); /*从低位开始还原数位,如1=1*10^1;10=1*10^2;100=10*10^3;...再把他们相加,也就是s1,合成完整数字。如111*/
s2+=s1; /*把每次合成的值保存在s2中,作为题目中的加数之一*/
}
alert(s2);//从题目的式子可以看出,1+11+111+11+1,其中出了111只被加一次其他都加了两次,所以直接把之前计算的s2*2再减去最后合成的一个数s1就可以了。
}else{
alert("请输入大于0的整数")
}
}
</script>
JS练习题2共8题的更多相关文章
- JS练习题1共7题
<p>1 一个新人入职,月工资为2000元的员工,每年涨工资5%,到退休时的月工资是多少?</p> <script> document.write(Math.rou ...
- Leetcode 简略题解 - 共567题
Leetcode 简略题解 - 共567题 写在开头:我作为一个老实人,一向非常反感骗赞.收智商税两种行为.前几天看到不止两三位用户说自己辛苦写了干货,结果收藏数是点赞数的三倍有余,感觉自己的 ...
- 2019前端面试系列——JS高频手写代码题
实现 new 方法 /* * 1.创建一个空对象 * 2.链接到原型 * 3.绑定this值 * 4.返回新对象 */ // 第一种实现 function createNew() { let obj ...
- 【js】Leetcode每日一题-制作m束花所需的最少天数
[js]Leetcode每日一题-制作m束花所需的最少天数 [题目描述] 给你一个整数数组 bloomDay,以及两个整数 m 和 k . 现需要制作 m 束花.制作花束时,需要使用花园中 相邻的 k ...
- 【js】Leetcode每日一题-完成所有工作的最短时间
[js]Leetcode每日一题-完成所有工作的最短时间 [题目描述] 给你一个整数数组 jobs ,其中 jobs[i] 是完成第 i 项工作要花费的时间. 请你将这些工作分配给 k 位工人.所有工 ...
- 【js】Leetcode每日一题-数组异或操作
[js]Leetcode每日一题-数组异或操作 [题目描述] 给你两个整数,n 和 start . 数组 nums 定义为:nums[i] = start + 2*i(下标从 0 开始)且 n == ...
- 【js】Leetcode每日一题-解码异或后数组
[js]Leetcode每日一题-解码异或后数组 [题目描述] 未知 整数数组 arr 由 n 个非负整数组成. 经编码后变为长度为 n - 1 的另一个整数数组 encoded ,其中 encode ...
- 【js】Leetcode每日一题-叶子相似的树
[js]Leetcode每日一题-叶子相似的树 [题目描述] 请考虑一棵二叉树上所有的叶子,这些叶子的值按从左到右的顺序排列形成一个 叶值序列 . 举个例子,如上图所示,给定一棵叶值序列为 (6, 7 ...
- 【js】Leetcode每日一题-子数组异或查询
[js]Leetcode每日一题-子数组异或查询 [题目描述] 有一个正整数数组 arr,现给你一个对应的查询数组 queries,其中 queries[i] = [Li, Ri]. 对于每个查询 i ...
随机推荐
- [python] python 中的" "和' '都是完全转义
dict = {"a" : "apple", "b" : "banana", "g" : " ...
- WebService 基础使用&cxf第三方Service使用
1.通过Jax-ws自己发布一个webservice 解析:用webservice发布HelloWorld JAX-WS本质就是通过Socket来实现的.2.WSDL文档描述如何直接变成java代码 ...
- nyoj 737 石子合并(一)。区间dp
http://acm.nyist.net/JudgeOnline/problem.php?pid=737 数据很小,适合区间dp的入门 对于第[i, j]堆,无论你怎么合并,无论你先选哪两堆结合,当你 ...
- python常用函数
dict排序: a={'A':4,'B':3,'C':2,'D':1} sorted(a.iteritems(),key=operator.itemgetter(1),reverse=False) # ...
- win8.1 vs2010 C++环境下 编译Android Adb.exe
1 IntelliSense: cannot open source file "usb100.h" adb 这是因为没有安装sdk造成的.win7下安装wdk,vs2010能够 ...
- Java 技术体系图
Java 程序员 高级特性 反射.泛型.注释符.自动装箱和拆箱.枚举类.可变 参数.可变返回类型.增强循环.静态导入 核心编程 IO.多线程.实体类. 集合类.正则表达式. XML 和属性文件 图形编 ...
- php包含(include/require)文件时的作用域
当一个php脚本被require/include时,他的变量作用域根据其上下文环境决定. 1.如果是在一个函数中require/include一个文件,则此文件中的变量作用域是这个函数的范围.也就是说 ...
- BHP编译器教程
BHP编译器教程 BHP是一个WEB模版编程语言编译器,生成PHP后端代码. 最简单的Helloworld例子 编写一个hello.bhp文件 <? $hello="hello,wor ...
- Jenkins 笔记
1.Jenkins是什么? 他是一个开源的自动化服务器,持续集成工具.由Java和上百个插件组成,支持编译,测试,部署任意的自动化项目. 2.怎么安装Jenkins? 方法一:从官网 https:// ...
- jquery基本选择器,一张页面全搞定
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...