牛客网做题笔记--洗牌问题

2024-04-10 20:18

本文主要是介绍牛客网做题笔记--洗牌问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述:

洗牌在生活中十分常见,现在需要写一个程序模拟洗牌的过程。 现在需要洗2n张牌,从上到下依次是第1张,第2张,第3张一直到第2n张。首先,我们把这2n张牌分成两堆,左手拿着第1张到第n张(上半堆),右手拿着第n+1张到第2n张(下半堆)。接着就开始洗牌的过程,先放下右手的最后一张牌,再放下左手的最后一张牌,接着放下右手的倒数第二张牌,再放下左手的倒数第二张牌,直到最后放下左手的第一张牌。接着把牌合并起来就可以了。 例如有6张牌,最开始牌的序列是1,2,3,4,5,6。首先分成两组,左手拿着1,2,3;右手拿着4,5,6。在洗牌过程中按顺序放下了6,3,5,2,4,1。把这六张牌再次合成一组牌之后,我们按照从上往下的顺序看这组牌,就变成了序列1,4,2,5,3,6。 现在给出一个原始牌组,请输出这副牌洗牌k次之后从上往下的序列。

输入描述:

第一行一个数T(T ≤ 100),表示数据组数。对于每组数据,第一行两个数n,k(1 ≤ n,k ≤ 100),
接下来一行有2n个数a1,a2,...,a2n(1 ≤ ai ≤ 1000000000)。表示原始牌组从上到下的序列。

输出描述:

对于每组数据,输出一行,最终的序列。数字之间用空格隔开,不要在行末输出多余的空格。

输入例子:

3
3 1
1 2 3 4 5 6
3 2
1 2 3 4 5 6
2 2
1 1 1 1

输出例子:

1 4 2 5 3 6
1 5 4 3 2 6
1 1 1 1

题目分析:

我们主要需要执行的操作就是洗牌这个过程,将洗完的牌返回以供继续洗牌,所以我们可以构造一个洗牌函数,根据传进来的参数给定其洗多少次,返回最后的那副牌即可。洗牌函数较简单,所以这道题目不难。

#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
vector<int> sort(vector<int>& res);
int main() {int time;int n,k;cin>>time;while(time){cin>>n>>k;vector<int> res(2*n);for(unsigned int i = 0;i < 2*n;++i){cin >> res[i];}while(k){res = sort(res);k--;}for(int i = 0;i < res.size();i++){if(i != res.size()-1)cout<<res[i]<<" ";elsecout<<res[i];}cout<<endl;time--;}return 0;
}
vector<int> sort(vector<int>& res){int size = res.size();int i = size/2;int j = 1;vector<int> r;while(i){r.push_back(res[size - j]);r.push_back(res[(size/2) - j]);j++;i--;}for(int i = 0;i < (r.size()/2);i++){swap(r[i],r[r.size()-i-1]);}return r;
}

洗牌函数就是这么一个过程:

  1. 将传进来的牌分成两部分(0~i == i~size),因为给出的测试用例肯定是偶数,所以我们也不用担心奇数情况,降低了难度
  2. 先将右边的牌的最后一张放入到新的牌中,再将左边的牌的最后一张放入,两边标记均往上跑一步
  3. 这么重复,直到跳出循环,也就是没牌的时候了
  4. 按照题目规则,将这些牌反序存储在数组中,就得到了新的一副牌

在主函数中,就是根据k的次数,执行k次洗牌过程,跳出k次洗牌这个过程之后,就将正确的结果输出即可。

注:但是这个题目在牛客上还没人用python做出过,我开始也是用python写,因为list很适合这些数组操作,但是最后发现不能按照它的要求输出一行,貌似python只有print函数。(如果有了解的,希望提醒一下博主,万分感谢。)

补充:

在别人代码上更改过的python:

import sys
def xipai(a,n):r=[a[i+j*n] for i in range(n) for j in range(2)]return r
while True:t = sys.stdin.readline().strip()if t == '':breakt = int(t)if t > 100:breakelse:for i in range(t):s = sys.stdin.readline().strip()[n,k]=s.split()n=int(n)k=int(k)if n > 100 or k >100:breaks = sys.stdin.readline().strip()if s == '':breaka=s.split()r=a[:]if len(r) != 2*n:continuewhile k>0 and k<=100 and len(r) == (2*n):i+=1r=xipai(r, n)if r==a:k=k%ik-=1if len(r) == (2*n):for i in range(2*n-1):print int(r[i]),print r[2*n-1]

牛客上的这道题目貌似有点问题,貌似都是提示数组越界或者非法访问,在牛客的讨论区也有一些人遇到这种类似的问题,望以后解决。

这篇关于牛客网做题笔记--洗牌问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/892040

相关文章

详谈redis跟数据库的数据同步问题

《详谈redis跟数据库的数据同步问题》文章讨论了在Redis和数据库数据一致性问题上的解决方案,主要比较了先更新Redis缓存再更新数据库和先更新数据库再更新Redis缓存两种方案,文章指出,删除R... 目录一、Redis 数据库数据一致性的解决方案1.1、更新Redis缓存、删除Redis缓存的区别二

oracle数据库索引失效的问题及解决

《oracle数据库索引失效的问题及解决》本文总结了在Oracle数据库中索引失效的一些常见场景,包括使用isnull、isnotnull、!=、、、函数处理、like前置%查询以及范围索引和等值索引... 目录oracle数据库索引失效问题场景环境索引失效情况及验证结论一结论二结论三结论四结论五总结ora

element-ui下拉输入框+resetFields无法回显的问题解决

《element-ui下拉输入框+resetFields无法回显的问题解决》本文主要介绍了在使用ElementUI的下拉输入框时,点击重置按钮后输入框无法回显数据的问题,具有一定的参考价值,感兴趣的... 目录描述原因问题重现解决方案方法一方法二总结描述第一次进入页面,不做任何操作,点击重置按钮,再进行下

解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题

《解决mybatis-plus-boot-starter与mybatis-spring-boot-starter的错误问题》本文主要讲述了在使用MyBatis和MyBatis-Plus时遇到的绑定异常... 目录myBATis-plus-boot-starpythonter与mybatis-spring-b

mysql主从及遇到的问题解决

《mysql主从及遇到的问题解决》本文详细介绍了如何使用Docker配置MySQL主从复制,首先创建了两个文件夹并分别配置了`my.cnf`文件,通过执行脚本启动容器并配置好主从关系,文中还提到了一些... 目录mysql主从及遇到问题解决遇到的问题说明总结mysql主从及遇到问题解决1.基于mysql

如何测试计算机的内存是否存在问题? 判断电脑内存故障的多种方法

《如何测试计算机的内存是否存在问题?判断电脑内存故障的多种方法》内存是电脑中非常重要的组件之一,如果内存出现故障,可能会导致电脑出现各种问题,如蓝屏、死机、程序崩溃等,如何判断内存是否出现故障呢?下... 如果你的电脑是崩溃、冻结还是不稳定,那么它的内存可能有问题。要进行检查,你可以使用Windows 11

如何安装HWE内核? Ubuntu安装hwe内核解决硬件太新的问题

《如何安装HWE内核?Ubuntu安装hwe内核解决硬件太新的问题》今天的主角就是hwe内核(hardwareenablementkernel),一般安装的Ubuntu都是初始内核,不能很好地支... 对于追求系统稳定性,又想充分利用最新硬件特性的 Ubuntu 用户来说,HWEXBQgUbdlna(Har

MAVEN3.9.x中301问题及解决方法

《MAVEN3.9.x中301问题及解决方法》本文主要介绍了使用MAVEN3.9.x中301问题及解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录01、背景02、现象03、分析原因04、解决方案及验证05、结语本文主要是针对“构建加速”需求交

Nginx、Tomcat等项目部署问题以及解决流程

《Nginx、Tomcat等项目部署问题以及解决流程》本文总结了项目部署中常见的four类问题及其解决方法:Nginx未按预期显示结果、端口未开启、日志分析的重要性以及开发环境与生产环境运行结果不一致... 目录前言1. Nginx部署后未按预期显示结果1.1 查看Nginx的启动情况1.2 解决启动失败的

CentOS系统使用yum命令报错问题及解决

《CentOS系统使用yum命令报错问题及解决》文章主要讲述了在CentOS系统中使用yum命令时遇到的错误,并提供了个人解决方法,希望对大家有所帮助,并鼓励大家支持脚本之家... 目录Centos系统使用yum命令报错找到文件替换源文件为总结CentOS系统使用yum命令报错http://www.cppc