Javascript——reduce函数(ZUCC智能终端与移动应用开发lab2)

题目

针对一个数组

const ages = [52, 44, 76, 7, 17, 36, 32, 32, 26, 28, 27, 49, 32, 33, 32, 33, 27, 25, 26, 38, 37, 31, 38, 38, 49, 29, 85, 32, 64, 32, 78]

计算平均值、中位数、 范围、方差

*方差是每个样本值与全体样本值的平均数之差的平方值的平均数

•要求使用Array中方法进行求解

•要求使用高阶函数(不能使用for、while等循环语句)

•要求某个步骤中使用reduce方法(自己选择即可,不唯一)

•所需方法(不限于PPT中的几个方法)在下面参考中寻找

https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Array

题解

const ages = [52, 44, 76, 7, 17, 36, 32, 32, 26, 28, 27, 49, 32, 33, 32, 33, 27, 25, 26, 38, 37, 31, 38, 38, 49, 29, 85, 32, 64, 32, 78]
//avg
let avg = 0;
let sum = ages.reduce((prev,cur)=>{
  prev+=cur;
  return prev;
},0)
avg = sum/ages.length;
console.log("平均值为"+avg);//output is 平均值为38.225806451612904
console.log("------------"); 
													

ages.sort((a,b)=>{
  return a-b;
});
// console.log(ages);n
// console.log(ages.length);
let mid = 0;
if(ages.length%2===0){
  const pos = ages.length/2;
  mid = (ages[pos]+ages[pos-1])/2;
}
else {
  const pos = (ages.length-1)/2;
  mid = ages[pos];

}

console.log("中位数"+mid);  //output is 中位数32
console.log("------------");

console.log("范围["+ages[0]+","+ages[ages.length-1]+"]");//output is 范围[7,85]
console.log("------------");
const cVariance = (ages,avg)=>{
  let sum = 0;
  ages.forEach((val)=>{
    sum+=Math.pow(val-avg,2);
  })
  return sum/ages.length;
}

console.log("方差为"+cVariance(ages,avg)); //output is 方差为290.4328824141519


reduce函数

语法

array.reduce(function(total, currentValue, currentIndex, arr), initialValue)

高级用法

统计数组元素出现次数
const names = ["zjx","zs","cg","zb","xg","zjx"];
const nameCnt = names.reduce((prev,cur)=>{
  if(cur in prev){
    prev[cur]++;
  }
  else {
    prev[cur] =1;
  }
  return prev;
},{});
console.log(nameCnt);

数组去重

const arr = [1,2,3,3,3,4,2,1];
const newArr = arr.reduce((prev,cur)=>{
  if(!prev.includes(cur)){
    prev.push(cur);
  }
  return prev;
},[]);
console.log(newArr);

js reduce 用法详情

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
信号量是一种用于进程间通信和同步的机制。它是一个计数器,用于保证在共享资源上的互斥访问。在Linux系统中,可以使用信号量来实现进程间的同步和互斥。以下是信号量的基本概念: - 计数器:信号量的值是一个计数器,它可以被多个进程共享。 - P操作:当一个进程需要访问共享资源时,它必须执行P操作,该操作会将信号量的值减1。如果信号量的值为0,则进程将被阻塞,直到信号量的值大于0。 - V操作:当一个进程使用完共享资源后,它必须执行V操作,该操作会将信号量的值加1。如果有进程正在等待该信号量,则唤醒其中一个进程继续执行。 在ZUCC中,可以使用信号量来实现进程的同步和互斥。首先,需要使用semget函数创建一个信号量集合,并使用semctl函数对信号量进行初始化。然后,可以使用semop函数执行P和V操作。例如,下面是一个简单的示例程序,用于演示信号量的使用: ```c #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <sys/sem.h> #define SEM_KEY 1234 union semun { int val; struct semid_ds *buf; unsigned short *array; }; int main() { int semid, pid; union semun arg; struct sembuf sb; // 创建信号量集合 semid = semget(SEM_KEY, 1, IPC_CREAT | 0666); if (semid == -1) { perror("semget"); exit(EXIT_FAILURE); } // 初始化信号量 arg.val = 1; if (semctl(semid, 0, SETVAL, arg) == -1) { perror("semctl"); exit(EXIT_FAILURE); } // 创建子进程 pid = fork(); if (pid == -1) { perror("fork"); exit(EXIT_FAILURE); } else if (pid == 0) { // 子进程执行P操作 sb.sem_num = 0; sb.sem_op = -1; sb.sem_flg = SEM_UNDO; if (semop(semid, &sb, 1) == -1) { perror("semop P"); exit(EXIT_FAILURE); } printf("Child process\n"); // 子进程执行V操作 sb.sem_num = 0; sb.sem_op = 1; sb.sem_flg = SEM_UNDO; if (semop(semid, &sb, 1) == -1) { perror("semop V"); exit(EXIT_FAILURE); } exit(EXIT_SUCCESS); } else { // 父进程执行P操作 sb.sem_num = 0; sb.sem_op = -1; sb.sem_flg = SEM_UNDO; if (semop(semid, &sb, 1) == -1) { perror("semop P"); exit(EXIT_FAILURE); } printf("Parent process\n"); // 父进程执行V操作 sb.sem_num = 0; sb.sem_op = 1; sb.sem_flg = SEM_UNDO; if (semop(semid, &sb, 1) == -1) { perror("semop V"); exit(EXIT_FAILURE); } exit(EXIT_SUCCESS); } return 0; } ``` 在上述代码中,创建了一个信号量集合,并将其初始化为1。然后,创建了一个子进程和一个父进程,它们分别执行P和V操作。由于信号量的初始值为1,因此父进程和子进程都可以顺利地执行。如果将信号量的初始值改为0,那么父进程和子进程都将被阻塞,直到有一个进程执行V操作为止。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值