学生答案对比正确答案获取得分【一天一个算法陶冶情操 | 算法练习生第3天】

js 复制代码
/**
 * 写一个函数,参数1为正确答案的数组, 参数2为学生答案的数组
 * 两个数组长度相同,要求该函数返回学生的得分(正确答案+4, 错误答案-1, 空白答案+0(y以空字符串表示))
 * 如果分数<0 则返回0
 */

function checkTest(param1, param2) {
  const reducer = (a, b, index) => {
    if (b === '') {
      return a
    }
    if (b === param1[index]) {
      return (a += 4)
    }
    return --a
  }
  const score = param2.reduce(reducer, 0)
  return score < 0 ? 0 : score
}
/**
 * 简析:
 * 通过reduce来完成累加, 在reduce的回调函数中来对分数加减进行判断,
 * 通过参数b(当前value)来进行相关判断, 需要注意的是错误答案, 返回的结果是--a,
 * 因为reduce是把回调函数的结果作为第一个参数传递到第二次的累加中,
 * 所以如果是a--的话, 其实返回的还是结果a, 而不是-1后的结果
 */

function checkTest2(param1, param2) {
  let scope = 0
  for (let i = 0; i < param1.length; i++) {
    if (param1[i] === param2[i]) {
      scope += 4
    } else if (param2[i] === '') {
      scope += 0
    } else {
      scope--
    }
  }
  return scope < 0 ? 0 : scope
}
/**
 * 简析
 * 这个就是一个简单的遍历 后面scope--就可以正常用了, 因为函数时基于顶层的scope做的处理, 执行完成后会减掉
 */

// 测试
console.log(checkTest([1, 5, 8, 3, 2], [1, 3, 8, 3, '']))
console.log(checkTest2([1, 5, 8, 3, 2], [1, 3, 8, 3, '']))
相关推荐
练习时长一年32 分钟前
LeetCode热题100(二叉树的最大路径和)
算法·leetcode·职场和发展
2401_872418787 小时前
算法入门:数据结构-堆
数据结构·算法
漂流瓶jz7 小时前
Webpack如何实现万物皆可import?loader的使用/配置/手写实践
前端·javascript·webpack
ZC跨境爬虫7 小时前
跟着 MDN 学CSS day_41:显式轨道、隐式网格与区域命名放置
前端·javascript·css·ui·交互
修己xj8 小时前
告别手动存图!这款叫 Fatkun 的浏览器插件,简直是素材收集神器
前端
xwz小王子8 小时前
手术机器人登上Science Robotics:2毫米纤细手臂,从3厘米切口完成腰椎神经减压
算法·机器人
袋鼠云数栈9 小时前
从前端到基础设施,ACOS 如何打通企业全链路可观测
运维·前端·人工智能·数据治理·数据智能
AskHarries9 小时前
系统提示词、开发者指令和用户输入的优先级
java·前端·数据库
黎阳之光9 小时前
视频孪生智护供水生命线:黎阳之光赋能医疗与园区水务高质量升级
运维·物联网·算法·安全·数字孪生
Moment9 小时前
长上下文会最终杀死 Rag 吗?
前端·javascript·后端