算法实现研究-座位分组

需求概况

这个需求有实际的应用场景,就是教室中座位的分组。这个分组可以用于考试时的座位分配,增加满足不同组考生不能相邻的业务规则。

情况是这样的,有一个教室,其中有MxN个座位。它们的编号,就是从1编到MxN。编号规则就是按行从左到右依次编号,如一个6x5和5x6的座位布局,编号方式分别如下:

js 复制代码
01 02 03 04 05 
06 07 08 09 10 
11 12 13 14 15 
16 17 18 19 20 
21 22 23 24 25 
26 27 28 29 30


01 02 03 04 05 06
07 08 09 10 11 12
13 14 15 16 17 18
19 20 21 22 23 24
25 26 27 28 29 30

现在的需求就是,将教室中的座位,分为两组,使在同一组中的任意两个座位,都不会相邻,相邻的定义,就是前后左右直接相连。显然这也会导致数组中元素的数量也基本相等(平均分成两组)。这个计算方法的输入就是M(行数)和N(列数);输出是两个数组,数组中的元素就是座位的编号。

实现

如果我们认真观察座位编号的布局,就会发现,最简单的方式,就是"画斜线"来分组,相邻斜线上的两组元素,肯定不相邻。按照这个基本构思,编写的示例和测试代码如下:

js 复制代码
const g1 = (x,y)=>{
    let i,
    ilast = x * y,
    igroup = [[],[]];

    for (i=1;i<=ilast;i++) {
        if (y % 2) {
            igroup[i%2 ? 0 : 1].push(i);
        } else if ((0 | (i-1) / y) % 2) {
            igroup[(i+1) % 2 ? 0 : 1].push(i);
        } else {
            igroup[i % 2 ? 0 : 1].push(i);
        };
    };

    return igroup;
}; 

let 
g = g1(5,6);
console.log(g[0].join(),"\n",g[1].join());

g = g1(6,5);
console.log(g[0].join(),"\n",g[1].join());

简单分析一下:

首先将座位布局分为两大类,列数为奇数和列数为偶数的。

对于列数为奇数的情况,非常简单,就是所有奇数编号为一组,偶数编号为一组。

对于列数为偶数的情况,稍微复杂一点。对于偶数行(包括第一行)的元素,处理方式就是按照列的奇偶来分组。对于奇数行的元素,将这个元素的值+1,然后按奇偶分组。

所以,最后就是遍历整个编号数组,按照这三种情况来将当前的元素,放在奇数组,或者偶数组中。最后的测试代码,我们就可以看到各种情况的计算结果。

相关推荐
草履虫建模1 天前
力扣算法 1768. 交替合并字符串
java·开发语言·算法·leetcode·职场和发展·idea·基础
naruto_lnq1 天前
分布式系统安全通信
开发语言·c++·算法
Mr Xu_1 天前
告别冗长 switch-case:Vue 项目中基于映射表的优雅路由数据匹配方案
前端·javascript·vue.js
Jasmine_llq1 天前
《P3157 [CQOI2011] 动态逆序对》
算法·cdq 分治·动态问题静态化+双向偏序统计·树状数组(高效统计元素大小关系·排序算法(预处理偏序和时间戳)·前缀和(合并单个贡献为总逆序对·动态问题静态化
前端摸鱼匠1 天前
Vue 3 的toRefs保持响应性:讲解toRefs在解构响应式对象时的作用
前端·javascript·vue.js·前端框架·ecmascript
sleeppingfrog1 天前
zebra通过zpl语言实现中文打印(二)
javascript
爱吃rabbit的mq1 天前
第09章:随机森林:集成学习的威力
算法·随机森林·集成学习
(❁´◡`❁)Jimmy(❁´◡`❁)1 天前
Exgcd 学习笔记
笔记·学习·算法
YYuCChi1 天前
代码随想录算法训练营第三十七天 | 52.携带研究材料(卡码网)、518.零钱兑换||、377.组合总和IV、57.爬楼梯(卡码网)
算法·动态规划
未来之窗软件服务1 天前
未来之窗昭和仙君(六十五)Vue与跨地区多部门开发—东方仙盟练气
前端·javascript·vue.js·仙盟创梦ide·东方仙盟·昭和仙君