加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

在Scala中使用带有Int的“或”运算符

发布时间:2020-12-16 10:05:10 所属栏目:安全 来源:网络整理
导读:我需要将数据拆分成列.空白空间必须分布在最终列中.因此,如果我有四个元素和三列,则列将具有以下数量的元素:2,1和1. 我需要知道有多少列已满.答案是: val full = data.length % NUMBER_OF_COLUMNS 问题是项目数是列数的倍数,这将返回零,这不是我想要的.所
我需要将数据拆分成列.空白空间必须分布在最终列中.因此,如果我有四个元素和三列,则列将具有以下数量的元素:2,1和1.

我需要知道有多少列已满.答案是:

val full = data.length % NUMBER_OF_COLUMNS

问题是项目数是列数的倍数,这将返回零,这不是我想要的.所以我能做到:

val full = if (data.length % NUMBER_OF_COLUMNS == 0) NUMBER_OF_COLUMNS else 
  data.length % NUMBER_OF_COLUMNS

这有效,但感觉不像“Scala一样”.这绝对是冗长而笨拙的,其余操作需要存储或执行两次. (在这里,我选择了后一种选择.)

有没有更好的办法?

在Python中,我所做的基本上是使用带有Int的or运算符,如下所示:

full = len(data) % NUMBER_OF_COLUMNS or NUMBER_OF_COLUMNS

完成.但我不能想到Scala中有类似的东西.它不存在还是我根本没有看到它?

解决方法

像这样使用模式匹配

len % nCols match {
  case 0 => nCols
  case v => v
}

请注意,第二个模式匹配任何(非零)值并提供已计算的mod值.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读