函数练习

函数练习

  1. 求圆的周长
<script>
var pi = Math.PI;
function getLong(r){
	var long = 2*pi*r;
	return long;
}
console.log(getLong(1));
</script>
  1. 求圆的面积
<script>
var pi = Math.PI;
function getArea(r){
	var area = pi*r*r;
	return area;
}
console.log(getArea(1));
</script>
  1. 求两个数中的最大值
<script>
function getMax(num1,num2){
	if(num1>num2){
		return num1;
	}
	return num2;
	//使用三元运算:return num1>num2?num1:num2;
}
console.log(getMax(1,2));
</script>
  1. 求三个数中的最大值
<script>
function getMax(a,b,c){
	var d = a>b?a:b;
	return d>c?d:c;
}
coonsole.log(getMax(1,2,3));
</script>
  1. 求一组数中的最大值
function getArrMax(array){
	var max= array[0];//max默认为数组中的最大值,可以减少一次比较的次数
	for(var i=; i<array.length; i++){
		if(array[i]>max){
			max = array[i];
		}
	}
	return max;//等for循环执行完之后再return
}
var arr = [1,2,3,4,5,6,7];
console.log(getArrMax(arr));
  1. 求一组数中的最小值
var arr = [0,1,2,3,4,5,6];
function getArrMin(array){
//用的必须是形参中数组中的某一项。
	var min = array[0];
	for(var i = 0; i<array.length; i++){
		if(array[i]<min){
			min = array[i];
		}
	}
	console.log(getArrMin(arr));
}
  1. 翻转数组,返回一个新数组。
//方法1:创建新数组
<script>
function getFilp(array){
	var newArr = [];
	for(var i=array.length-1; i>=0; i--){
		newArr[newArr.length] = array[i];
	}
	return newArr;
}
console.log(getFilp(arr));
</script>

//方法2:直接修改原数组
<script>
function getFilp(array){
	for(var i = 0;i<array.length/2; i++){
		var temp = array[i];
		array[i] = array[array.length-1-i];
		array[array.length-1-i] = temp;
	}
	return array;
}
console.log(getFilp(array));
</script>
  1. 对数组进行排序,从小到大
function bubbleArr(array){
	for(var i=0; i<array.length-1; i++){
		var bool = true;
		for(var j=0; j<array.length-1-i; j++){
			if(array[j]>array[j+1]){
				var temp = array[j];
				array[j] = array[j+1];
				array[j+1] = temp;
				bool = false;
				}
		}
		if(bool){
			return array;
		}
	}
}
  1. 求阶乘
<script>
function factotial(num){
	var sumJc = 1;
	for(var i = 1; i<=num; i++){
		
		sumJc*=i;
	}
	return sumJc;
}
console.log(factotial(num));
</script>
  1. 求阶乘的和(函数嵌套)
<script>
//提示:本例用到了上一个求阶乘的函数
function getJc(number){
	var sum = 0;
	for(var i=1; i<=number; i++){
		sum += factotial(i);
	}
	return sum;
}
console.log(getJc(number));
</script>
  1. 判断一个数是否是素数(质数)
//思路:除了自身和1以外,不能被其他数整除	
//注意点:
◇ :必须用for循环实现
◇ :判断是否是素数,所以它的返回值应该是true或者false.
<script>
function isPrime(num){
	for(var i=2;i<num;i++){   //为什么是从(2,num),就是为了检查除了1和他本身除外的那些数怎么样.
		if(num%i===0){
			return false;
		}
	}
	return true;//必须等到判断完所有的i值后再返回true;
}
</script>

打卡:2019/7/5 21:53
希望量变引起质变!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值