真题集P93---2017年计专真题

news2025/1/4 19:22:21

真题集P93---2017年计专真题

    • 思路:模拟
    • 代码
    • 思路
      • 一:哈希表法
      • 二:排序法 (利用排序去重)
      • 三:拓展
    • 代码(仅思路一)

在这里插入图片描述

思路:模拟

1、接口介绍

int turnNum(int num[], int nums):拿来一个数组,将之表示的二进制数转化成为十进制
bool is_valid(int path[], int n, int sum, int times):判断当前生成的路径是不是符合题意的路径
void dfs(int path[], int n, int sum, int times):生成全排列的函数,在产生的元素个数等于2^n时候进行判断该序列合不合法,合法就输出,让所有一切别的产生序列函数停止

2、设计思路
<1>输入n,需要对2^n个位置,产生0或者1,用dfs产生全排列,当个数达到要求,判断该序列是否合法
<2>拿到序列之后,用指针i从头扫到尾,在每个i出,连续提取n个数,放入数组,转化成10进制,看出现过了吗,未出现过,计数,最后计数为2^n个,为合法序列

代码

在连续取数时候,为了防止越界,且根据题意,用循环的方式即可

#include <iostream>
#include <string>
#include <stack>
#include <queue>
#include <unordered_map>
#include <vector>
#include <algorithm>
using namespace std;
bool find_ans = false;
int turnNum(int num[], int nums) {//转十进制
	int ans = 0;
	for (int i = 0; i < nums; i++) {
		ans = ans * 2 + num[i];
	}
	return ans;
}
bool is_valid(int path[], int n, int sum, int times) {
	bool visit[1000];
	int num = 0;
	for (int i = 0; i < sum; i++) {
		visit[i] = false;
	}
	for (int i = 0; i < n; i++) {
		int cur[1000] = {};
		int j = 0;//记录从path中,从i后面,抽取出的第j个数,共抽取出times个,times表示2^n中的n
		while (j < times) {
			int p = path[i % sum + j];//根据题意,如果最后越界,采用循环的方式
			cur[j++] = p;//送到cur数组准备一会转化成十进制数
		}
		int tmp = turnNum(cur, times);
		if (!visit[tmp]) {
			visit[tmp] = true;
			num++;
		}
	}
	if (num == sum) {
		return true;
	}
	return false;
}
void dfs(int path[], int n, int sum, int times) {//参数:记录排列的数组,数组中元素个数,总共应该有多少个元素,2^n中的n
	if (n == sum) {//此次排列产生完毕
		if (is_valid(path, n, sum, times)) {
			find_ans = true;//说明已经找到答案,让别的函数见到此快速退出
			for (int i = 0; i < n; i++) {
				cout << path[i] << ' ';
			}
		}
		return;
	}
	if (find_ans) {//已经找到答案,快速退出 
		return;
	}
	path[n] = 0;
	dfs(path, n + 1, sum, times);
	path[n] = 1;
	dfs(path, n + 1, sum, times);
	return;
}
void function_six() {
	int n;
	cin >> n;
	int sum = pow(2, n);
	int path[1000] = {};
	dfs(path, 0, sum, n);
	return;
}

在这里插入图片描述

思路

一:哈希表法

1、选一个链作为主链,先扫一遍,把元素放入对应的哈希表,注意,最后指针要停在最后一个节点上。
2、进入副链,当前元素,未在之前集合出现,连在主链末尾。
3、一定注意,数据域是整数,包括正整数,负整数,0,所以用两个数组模拟哈希。

二:排序法 (利用排序去重)

这个方法在求并集时候并不好用,作为了解,过程如下
在这里插入图片描述
在这里插入图片描述

三:拓展

一旦不求并集,而改求交集,那么排序法就很好,过程如下:
在这里插入图片描述
链表冒泡排序见第八章–排序

代码(仅思路一)

#include <iostream>
#include <string>
#include <stack>
#include <queue>
#include <unordered_map>
#include <vector>
#include <algorithm>
using namespace std;
typedef struct node {
	int val;
	node* next;
};
node* function_seven(node* q, node* p) {
	bool hash[10000];//代表正数哈希
	bool hash_ano[10000];//代表负数哈希
	for (int i = 0; i < 10000; i++) {
		hash[i] = false;
		hash_ano[i] = false;
	}
	node* cur = q;//q链作为主链,之后全往q链上面挂
	while (cur->next != nullptr) {
		cur->val >= 0 ? hash[cur->val] = true : hash_ano[abs(cur->val)] = true;//根据正负放入正确的哈希表
		cur = cur->next;
	}
	node* last = p;
	while (last != nullptr) {
		if (last->val >= 0 && hash[last->val]) {//在正确的哈希表中找是否出现过
			last = last->next;
			continue;
		}
		if (last->val < 0 && hash_ano[abs(last->val)]) {//在正确的哈希表中找是否出现过
			last = last->next;
			continue;
		}
		last->val >= 0 ? hash[last->val] = true : hash_ano[abs(last->val)] = true;//根据数值存入正确的哈希表
		node* tmp = last;//连接节点,先标记这个节点
		last = last->next;
		
		cur->next = tmp;
		cur = tmp;
		cur->next = nullptr;
	}
	return q;//返回主链
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/43152.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

数据库约束

约束概述 为什么需要约束 数据完整性&#xff08;Data Integrity&#xff09;是指数据的精准性&#xff08;Accuracy&#xff09;和可靠性&#xff08;Reliability&#xff09;。它是防止数据库中存在不符合语义规定的数据和防止因错误信息的输入输出造成无效操作或错误信息而…

种草软文怎么写?分享一些超实用的种草软文写作技巧。

一提起“种草”这个词语&#xff0c;想必很多小伙伴都不陌生&#xff0c;我们都有“被种草”的经历&#xff0c;指的就是把一件商品推荐给大家&#xff0c;分享给需要的人&#xff0c;然后促成销售转化的过程。 在一些主流的内容平台&#xff0c;比如知乎、小红书、得物、公众…

Android 9.0 MediaPlayer播放流程分析

1.MediaPlayer初始化流程 EventHandler是后面处理数据回调的handler. 在AudioFlinger.cpp中获取nextUniqueId&#xff1a; audio_unique_id_t AudioFlinger::nextUniqueId(audio_unique_id_use_t use) {// This is the internal API, so it is OK to assert on bad parameter.…

18-1、k8s 对外服务之ingress

一、什么是ingress 原来的项目是部署在一台电脑上的&#xff0c;这样爬取速度虽然很快&#xff0c;但是我们还能提升&#xff0c;联想到分布式的思想&#xff0c;我们是否可以通过多台电脑进行配合爬取&#xff0c;这样我们的爬取速度就能大幅度提升。 …

【Mysql】数据库的基本操作和表的增删改查

本章内容是,用sql语言实现对数据库的基本操作和表的基本操作 文章目录前言1. 数据库的基本操作1.1 创建数据库1.2 查看数据库1.3 选中数据库1.4 删除数据库2. 数据库基本数据类型3. 表的基本操作3.1 创建表3.2 显示数据库中的表3.3 查看表的构造3.4 删表4. 表的增删改查4.1 增加…

基于PHP+MySQL汽车查询系统的设计与实现

随着时代的发展,汽车已经逐渐成为人们代步的主要工具之一,按时因为工业的发展,汽车的品牌和型号也层出不穷,如此多的汽车信息如何能够让爱车人士更好的 汽车查询系统的主要功能包含&#xff1a;汽车的类别管理、汽车的信息管理、留言管理、用户的管理等。网站分为管理员、会员用…

开放与融合趋势下,工业互联网安全破圈之道

作者 | 伍杏玲 出品 | CSDN 在工业 4.0 和数字经济的发展促进下&#xff0c;工业互联网作为连接工业经济的重要要素&#xff0c;成为推动数字经济发展的重要基础设施。据统计&#xff0c;到 2025 年&#xff0c;全球 IoT 连接设备数量达 519 亿。 然而在 OT 和 IT 融合趋势下…

1721. 交换链表中的节点-仅遍历一次链表-考研满分答案

1721. 交换链表中的节点-仅遍历一次链表 给你链表的头节点 head 和一个整数 k 。 交换 链表正数第 k 个节点和倒数第 k 个节点的值后&#xff0c;返回链表的头节点&#xff08;链表 从 1 开始索引&#xff09;。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5], k…

第1关:Hbase数据库的安装

在安装HBase之前你需要先安装Hadoop和Zookeeper&#xff0c;如果你还没有安装可以通过这两个实训来学习&#xff1a;Hadoop安装与配置&#xff0c;Zookeeper安装与配置。 本次实训的环境已经默认安装好了Hadoop&#xff0c;接下来我们就开始安装配置HBase吧。 HBase安装 HBas…

浙大MPA常规批复试上岸经验分享

在经历笔试和面试的备考后&#xff0c;去年终于来到了复试环节&#xff0c;好在通过自己的不懈努力和不放松的精神&#xff0c;最终成功上岸&#xff0c;现在把个人的备考经验做整理为大家做个参考&#xff01; 一、复试前准备&#xff1a;在正式复试前建议一定要对浙大MPA项目…

【综合评价分析】topsis评价 原理+完整MATLAB代码+详细注释+操作实列

【综合评价分析】topsis评价 原理完整MATLAB代码详细注释操作实列 文章目录 1、TOPSIS法的原理 2、TOPSIS法案例分析 3.建立模型并求解 3.1数据预处理 3.2代码实现数据预处理 3.3 本案例中数据预处理的运用 4.计算距离和评价指标 4.1 代码 4.2 运行结果 5.总结 1、T…

基于Jsp的OA企业人事管理系统【论文、数据库设计、源码、开题报告】

数据库脚本下载地址&#xff1a; https://download.csdn.net/download/itrjxxs_com/86500769 主要使用技术 SpringspringMVCmybatisjspccsjsMysqlTomcat 功能介绍 部门管理&#xff1a;支持对部门信息&#xff08;部门名称、部门类型、电话、传真、描述、上级部门&#xff…

外卖项目(项目优化1)10---缓存优化

优化前面已经创建好的项目&#xff1a;将一些问题进行优化处理。本节主要解决是下面的问题。 前面的的项目&#xff0c;是将短信验证码等数据缓存到session中&#xff0c;该部分进行优化后&#xff0c;是将数据内容缓存到Redis中。 目录 一、使用git管理代码&#xff08;对ID…

Guava环境设置

Guava本地环境设置 这部分指导如何下载和设置Java在机器上。请按照以下步骤来设置环境。 Java SE免费提供链接&#xff1a;下载Java。所以&#xff0c;根据操作系统下载对应版本。 按照说明下载java和运行.exe 在机器上&#xff0c;并按说明安装Java。一旦机器上安装了Java&…

Leetcode原题电话号码的字母组合的两种解法【BFS-DFS】

来源&#xff1a;LeetCode 第17题【公众号&#xff1a;数据结构和算法】 给定一个仅包含数字2-9的字符串&#xff0c;返回所有它能表示的字母组合。答案可以按任意顺序返回。给出数字到字母的映射如下&#xff08;与电话按键相同&#xff09;。注意1不对应任何字母。 示例1&am…

浅析分布式数据库

前言 随着信息技术的迅猛发展&#xff0c;各行各业产生的数据量呈爆炸式增长&#xff0c;传统集中式数据库的局限性在面对大规模数据处理中逐渐显露&#xff0c;从而分布式数据库应运而生。分布式数据库是在集中式数据库的基础上发展起来的&#xff0c;是分布式系统与传统数据…

java刷题day 06

一. 单选题&#xff1a; 解析&#xff1a;最终类也叫密封类&#xff0c;是被final修饰的类&#xff0c;不能被继承 解析&#xff1a; A&#xff1a;6入&#xff0c;5 入&#xff0c;5出&#xff0c;4入&#xff0c;4出&#xff0c;3入&#xff0c;3出&#xff0c;6出&#xff0…

SpringBoot 封装 HBase 操作工具类

最近项目中用到了Hbase相关的操作并封装成工具类&#xff0c;我的Hbase服务器端版本是2.1.0&#xff0c;图示如下&#xff1a; 特此记录便于日后查阅。 一、pom.xml 依赖 <dependency><groupId>org.apache.hbase</groupId><artifactId>hbase-shaded-…

【C++】快速入门list的使用

文章目录一、引入二、构造三、迭代器四、增删查五、其他操作一、引入 list的本质是带头双向循环链表&#xff0c;对于带头双向循环链表我们可是比较熟悉的了。本文只对list的一些常用接口进行说明&#xff0c;对于其他一些接口可自行查看文档。 二、构造 void Test() {list<…

Simple Black-box Adversarial Attacks

Abstract 我们提出了一种有趣的简单方法&#xff0c;用于在黑盒环境中构建对抗性图像。 与白盒场景相比&#xff0c;构建黑盒对抗图像对查询预算有额外的限制&#xff0c;而有效的攻击至今仍是一个悬而未决的问题。 仅在连续值置信分数的温和假设下&#xff0c;我们的高效查询…