DS|静态查找

题目一:DS静态查找 -- 顺序查找

题目描述:

给出一个队列和要查找的数值,找出数值在队列中的位置,队列位置从1开始

要求使用带哨兵的顺序查找算法

输入要求:

第一行输入n,表示队列有n个数据
第二行输入n个数据,都是正整数,用空格隔开
第三行输入t,表示有t个要查找的数值
第四行起,输入t个数值,输入t行

输出要求:

每行输出一个要查找的数值在队列的位置,如果查找不成功,输出字符串error

输入样例:

8
33 66 22 88 11 27 44 55
3
22
11
99

输出样例:

3
5
error

代码示例:

#include <iostream>
#include <vector>
#include <queue>
using namespace std;

int sequenceSearch(int arr[], int key, int n) {
	int i = n;
	arr[0] = key;//设置哨兵
	while (arr[i] != key) i--;
	return i;
}

int main() {
	int n;
	int array[10010];
	cin >> n;
	for (int i = 1; i <= n; i++) cin >> array[i];

	int t;
	cin >> t;
	while (t--) {
		int k;
		cin >> k;
		int index = sequenceSearch(array, k, n);
		if (index) cout << index << endl;
		else cout << "error" << endl;
	}
}

题目二:DS静态查找 -- 折半查找

题目描述:

给出一个队列和要查找的数值,找出数值在队列中的位置,队列位置从1开始

要求使用折半查找算法

输入要求:

第一行输入n,表示队列有n个数据
第二行输入n个数据,都是正整数,用空格隔开
第三行输入t,表示有t个要查找的数值
第四行起,输入t个数值,输入t行

输出要求:

每行输出一个要查找的数值在队列的位置,如果查找不成功,输出字符串error

输入样例:

8
11 22 33 44 55 66 77 88
3
22
88
99

输出样例:

2
8
error

代码示例:

#include <iostream>
#include <vector>
#include <queue>
using namespace std;

int binarySearch(int arr[], int l, int r, int key) {
    while (l < r) {
        int mid = l + r >> 1;
        if (arr[mid] >= key) r = mid;
        else l = mid + 1;
    }
    return l;
}

int main() {
    int n;
    int array[10010];
    cin >> n;
    for (int i = 1; i <= n; i++) cin >> array[i];

    int t;
    cin >> t;
    while (t--) {

        int num;
        cin >> num;
        int index = binarySearch(array, 1, n, num);
        if (array[index] != num) cout << "error" << endl;
        else cout << index << endl;
    }
}

题目三:DS静态查找 -- 顺序索引查找

题目描述:

给出一个队列和要查找的数值,找出数值在队列中的位置,队列位置从1开始

要求使用顺序索引查找算法,其中索引表查找和块内查找都采用不带哨兵、从头开始的顺序查找方法。

输入要求:

第一行输入n,表示主表有n个数据
第二行输入n个数据,都是正整数,用空格隔开
第三行输入k,表示主表划分为k个块,k也是索引表的长度
第四行输入k个数据,表示索引表中每个块的最大值
第五行输入t,表示有t个要查找的数值
第六行起,输入t个数值,输入t行

输出要求:

每行输出一个要查找的数值在队列的位置和查找次数,数据之间用短划线隔开,如果查找不成功,输出字符串error

输入样例:

18
22 12 13 8 9 20 33 42 44 38 24 48 60 58 74 57 86 53
3
22 48 86
6
13
5
48
40
53
90

输出样例:

3-4
error
12-8
error
18-9
error

代码示例:

#include <iostream>
#include <vector>
#include <queue>
using namespace std;

int main() {
	int n;
	int array[1010];
	cin >> n;
	for (int i = 1; i <= n; i++) cin >> array[i];

    int x;
    cin >> x;
    int index[100], maxnum[100];
    for (int i = 1; i <= x; i++) cin >> maxnum[i];

    int pos = 2, maxindex = 1;
    index[1] = 1;
    for (int i = 2; i <= x; i++) {
        for (int j = 1; j < n; j++) {
            if (array[j] > maxnum[maxindex]) {
                index[pos] = j;
                maxindex++;
                pos++;
            }
        }
    }

	int t;
	cin >> t;
    while (t--) {

        int num;
        cin >> num;
        int cnt = 0;
        int startpos = 0;
        for (int i = 1; i <= x; i++) {
            cnt++;
            if (num <= maxnum[i]) {
                startpos = index[i];
                break;
             }
        }

        if (!startpos) {
            cout << "error" << endl;
            continue;
        }

        for (int i = startpos; i <= n; i++) {
            cnt++;
            if (num == array[i]) {
                cout << i << "-" << cnt << endl;
                break;
            }
            else if (i == n) {
                cout << "error" << endl;
            }
        }
    }
}

题目四:DS静态查找 -- 折半查找求平方根

题目描述:

假定输入y是整数,我们用折半查找来找这个平方根。在从0到y之间必定有一个取值是y的平方根,如果我们查找的数xy的平方根小,则x2<y,如果我们查找的数xy的平方根大,则x2>y,我们可以据此缩小查找范围,当我们查找的数足够准确时(比如满足|x2-y|<0.00001),就可以认为找到了y的平方根。

比如求5的平方根x,则x一定满足0<=x<=5,取x为(5+0)/2=2.5,因为2.5的平方为6.25>5,所以x一定小于2.5,也即x满足0<=x<=2.5,取x为1.25,以此类推

最后求得5的平方根为2.236

输入要求:

第1行输入一个整数n(<100),表示有n个数

从第2行起到第n+1行输入n个整数

输出要求:

输出n个数的平方根,精确到小数点后三位。

输入样例:

2
13
5

输出样例:

3.606
2.236

代码示例:

#include <iostream>
#include <cmath>
#include <algorithm>
#include <iomanip>
using namespace std;

const double eps = 1e-8;   // eps 表示精度,取决于题目对精度的要求


int main(){
    int t;
    cin >> t;
    while (t--) {
        double n;
        cin >> n;

        double l, r;
        if (n >= 1) l = 1, r = n;
        else if (n > 0) l = 0, r = 1;
        else if (n <= -1) l = n, r = -1;
        else l = -1, r = 0;

        while (r - l > eps)
        {
            double mid = (l + r) / 2;
            if (pow(mid, 2) >= n) r = mid;
            else l = mid;
        }
        cout << fixed << setprecision(3) << l << endl;
    }
}

题目五:DS静态查找 -- 两个有序序列的中位数

题目描述:

已知有两个等长的非降序序列S1, S2, 设计函数求S1与S2并集的中位数。有序序列A​0​​,A​1​​,⋯,A​N−1​​的中位数指A​(N−1)/2​​的值,即第⌊(N+1)/2⌋个数(A​0​​为第1个数)。

只需考虑中位数唯一的情况

4

输入要求:

输入分三行。第一行给出序列的公共长度N(0<N≤100000),随后每行输入一个序列的信息,即N个非降序排列的整数。数字用空格间隔。

输出要求:

在一行中输出两个输入序列的并集序列的中位数。

输入样例:

5
1 3 5 7 9
2 3 4 5 6

输出样例:

4

代码示例:

#include <iostream>
#include <cmath>
#include <algorithm>
#include <iomanip>
using namespace std;

void quick_sort(int q[], int l, int r){
    if (l >= r) return;

    int i = l - 1, j = r + 1, x = q[(l + r) / 2];
    while (i < j){
        do i++; while (q[i] < x);
        do j--; while (q[j] > x);
        if (i < j) swap(q[i], q[j]);
    }
    quick_sort(q, l, j), quick_sort(q, j + 1, r);
}

int main() {
    int n;
    cin >> n;
    int array[100];
    for (int i = 0; i < 2 * n; i++)cin >> array[i];

    quick_sort(array, 0, 2 * n - 1);

    int center = (2 * n - 1) / 2;
    cout << array[center] << endl;

}

题目六:DS静态查找 -- 链表的有序构建和查找

题目描述:

单链表结点的存储结构包含两部分:数据、下一结点指针(默认为空)。

单链表包含头结点,存储实际数据的结点位置从1开始。

现输入一批无序的整数队列,编写程序完成以下要求

1)构建单链表并且把数据按递增顺序插入到链表中,并且统计非空指针发生变化的次数。

例如在初始只包含头结点的单链表中,依次插入3和2

当把3插入时,是头结点的next指针发生变化,初始头结点的next指针是空的,现在指向3的结点,所以不计入指针变化次数。

当把2插入时,它是插入到头结点和3结点之间,这时候头结点的next指针从指向3变成指向2,因此这次计入指针变化次数。

总之,如果是把一个空的next指针指向新的结点,则不计入变化次数;如果是把一个非空next指针修改指向新结点则计入变化次数。

2)实现对单链表的元素查找。输入一个链表位置,返回该位置对应的数据。如果位置非法则输出提示信息,看样例。

要求:必须使用单链表结构实现上述要求,并且不能用第三方算法库或容器类对象

输入要求:

第一行:第一个数字n表示样本数目,其后跟n个样本。

第二行:查找测试次数m 后跟m个待查找的位置。

输出要求:

第一行输出构建链表过程中,非空指针变化的总次数,格式看样本

第二行输出单链表创建后,从头到尾依次输出链表中元素数据

第三行到第n+1行,对每个查找位置,若结点存在,输出结点数据;否则输出error

输入样例:

6 1 8 5 2 4 3
4 0 2 10 6

输出样例:

非空指针变化4次
1 2 3 4 5 8
error
2
error
8

代码示例:

#include<iostream>
#include<cmath>
#include<iomanip>
#include<algorithm>
#include<cstring>
using namespace std;

struct Node {
    int data;
    Node* next;
    Node() :data(-1), next(nullptr) {}
    Node(int e) :data(e), next(nullptr) {}
};

class list {
private:    
    int num = 0;
    Node* head;
    int size;
public:
    list() {
        size = 0;
        head = new Node();
    }
    ~list() {}
    void Insert(int x) {
        Node* tmp = new Node(x);
        Node* s;
        s = head;
        while (1) {
            if (s->next == NULL) {
                s->next = tmp;
                break;
            }
            if (s->next->data > x) {
                num++;
                tmp->next = s->next;
                s->next = tmp;
                break;
            }
            s = s->next;
        }
        size++;
    }
    void Display() {
        Node* s;
        s = head;
        for (int i = 0; i < size - 1; i++) {
            s = s->next;
            cout << s->data << " ";
        }
        s = s->next;
        cout << s->data << endl;
    }
    int Find(int x) {
        Node* s;
        s = head;
        if (x > size)  return -1;
        else {
            for (int i = 0; i < x; i++) s = s->next;
            return s->data;
        }
    }
    int getNum() { return num; }
};

int main() {
    int n;
    cin >> n;
    list l;
    int x;
    while (n--) {
        cin >> x;
        l.Insert(x);
    }
    cout << "非空指针变化" << l.getNum() << "次" << endl;
    l.Display();
    int m, result;
    cin >> m;
    for (int i = 0; i < m; i++) {
        cin >> x;
        result = l.Find(x);
        if (result == -1) cout << "error" << endl;
        else cout << result << endl;
    }
    return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

PySimpleGUI图形界面实例|PDF表格转换Excel文件

实例要求&#xff1a; 使用PySimpleGUI做一个把单位考勤系统导出的pdf文件合并输出Excel的应用&#xff0c;故事出自&#xff1a;https://hannyang.blog.csdn.net/article/details/135395946 当时时间紧&#xff0c;没有好好做界面且输出csv文件了事。今天趁周六休息&#xf…

linux中最常用的用户信息命令

文章目录 linux中最常用的用户信息命令还有谁 last语法一般使用方法查看最近登陆的三个用户省略hostname显示最后一列显示主机IP地址 我是谁 whoami谁&#xff1f;who默认使用系统的运行时间显示表头信息显示登录的人员及总数 什么&#xff1f;谁&#xff1f;w (who & what…

Demo:基于elementplus的弹窗嵌套表单进行二次封装

基于elementplus的弹窗嵌套表单进行二次封装 所见即所得&#xff1a;简单封装方便工作 ProForm.vue代码&#xff1a; <!--* Author: 忆往昔* LastEditTime: 2024-01-6 14:36:00* email: 15871856064163.com --> <template><div class"penk-form-contain…

【SpringBoot实战专题】「开发实战系列」全方位攻克你的技术盲区之Spring定义Jackson转换Null的方法和实现案例

Spring自动定义Jackson转换Null得方法 背景MessageConverter 使用Jackson原生方式处理空字段&#xff08;次重点方案&#xff09;ObjectMapper的配置选项通过使用注解的方式 MappingJackson2HttpMessageConverter&#xff08;重点方案&#xff09;创建MappingJackson2HttpMessa…

WebStorm 创建一个Vue项目

一、下载并安装WebStorm 步骤一 步骤二 选择激活方式 激活码&#xff1a; I2A0QUY8VU-eyJsaWNlbnNlSWQiOiJJMkEwUVVZOFZVIiwibGljZW5zZWVOYW1lIjoiVU5JVkVSU0lEQURFIEVTVEFEVUFMIERFIENBTVBJTkFTIiwiYXNzaWduZWVOYW1lIjoiVGFvYmFv77yaSkVU5YWo5a625qG25rAIOa0uW3peS9nOWup…

Easycode模板,基于官方提供的Mybatis-plus模板改造

目录结构 模板亮点 1、接口类默认继承实体类 实体类不做任何修改保证类与表统一 2、实体类涵盖多种注解 日期格式编码、Long类型转String、字段自动填充 3、自带insertOrUpdateBatch方法 导入方式 {"author" : "Wsong","version" : "1.2.8…

SpringBoot+RocketMQ集群(dledger)部署完整学习笔记

文章目录 前言一、单台集群部署二、多台集群部署1.修改配置2.dashboard修改 三、整合springboot1.引入pom和修改yml2.编写消费者3.编写生产者4.测试效果 总结 前言 RocketMQ集群方式有好几种 官网地址 https://rocketmq.apache.org/zh/docs/4.x/deployment/01deploy 2m-2s-asy…

ATTCK视角下的信息收集:主机发现

目录 1、利用协议主动探测主机存活 利用ICMP发现主机 利用ARP发现主机 利用NetBIOS协议发现主机 利用TCP/UDP发现主机 利用DNS协议发现主机 利用PRC协议发现主机程序 2、被动主机存活检测 利用Browser主机探测存活主机 利用ip段探测主机存活 利用net命令探测主机存活…

unity C# 中通俗易懂LINQ使用案例

文章目录 1. 从数组或列表中查询元素**&#xff1a;2. **排序与分组**&#xff1a;3. **连接多个数据源**&#xff1a;4. **聚合操作**&#xff1a;5. **分页查询**&#xff1a;6. **多条件查询**&#xff1a;7. **转换和投影&#xff08;Select&#xff09;**&#xff1a;8. *…

jdbc源码研究

JDBC介绍 JDBC&#xff08;Java Data Base Connectivity,java数据库连接&#xff09;是一种用于执行SQL语句的Java API&#xff0c;可以为多种关系数据库提供统一访问&#xff0c;它由一组用Java语言编写的类和接口组成。 开发者不必为每家数据通信协议的不同而疲于奔命&#…

竞赛保研 基于深度学习的人脸专注度检测计算系统 - opencv python cnn

文章目录 1 前言2 相关技术2.1CNN简介2.2 人脸识别算法2.3专注检测原理2.4 OpenCV 3 功能介绍3.1人脸录入功能3.2 人脸识别3.3 人脸专注度检测3.4 识别记录 4 最后 1 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; 基于深度学习的人脸专注度…

Flask 会员列表展示

感谢编程浪子师傅的源码信息分享 web/controllers/member/Member.py # -*- coding: utf-8 -*- from flask import Blueprint,request,redirect,jsonify from common.libs.Helper import ops_render,iPagination,getCurrentDate,getDictFilterField,selectFilterObj from comm…

【uniapp】APP打包上架应用商-注意事项

初雪云-uniapp启动图自定义生成&#xff08;支持一键生成storyboard&#xff09; 一、修改App端上传图片/视频 uni.uploadFile let thatthis; uni.chooseImage({count: 1,sourceType: [camera,album],sizeType: [compressed, original],success: rey > {uni.showLoading({ t…

Linux操作系统——进程控制(一) 进程创建和进程终止

进程创建 fork函数 在linux中fork函数时非常重要的函数&#xff0c;它从已存在进程中创建一个新进程。新进程为子进程&#xff0c;而原进程为父进程。 #include <unistd.h> pid_t fork(void); 返回值&#xff1a;自进程中返回0&#xff0c;父进程返回子进程id&#xff…

BetaFlight开源代码之电流校准

BetaFlight开源代码之电流校准 1. 源由2. 分析2.1 常规逻辑2.2 数据流2.3 采样电路2.3.1 采样实现2.3.2 采样原理2.3.3 Layout参考2.3.4 INA169芯片2.3.5 INA169 Near-Zero Vsense 3. 原理4. 示例4.1 实测&转换数据4.2 线性拟合-小电流4.3 线性拟合-大电流4.4 大电流/小电流…

HDMI彩条显示实验与方块移动实验

一、HDMI接口简介 一种数字音视频接口标准&#xff0c;提供高质量的数字音视频传输&#xff0c;同时支持多通道音频、高分辨率视频和其他数据传输功能。提供更高的数据传输带宽&#xff08;带宽&#xff1a;1s内传输多少比特数据&#xff09; 数字传输&#xff1a; HDMI是一种全…

【VRTK】启用多种VR设备的Passthrough功能

【背景】 透视可以让VR头盔展现AR能力,通过VRTK,可以快速实现多种设备平台可用的透视功能。包括主流的Oculus,Pico等。整个不成不需要自己写代码。 【操作】 针对WaveXR,点击场景中的CameraRigsWaveXR-》WaveRig-》Camera Offset-》Main Camera,追加一个新组件,名为Und…

QT自定义信号和槽

信号和槽 介绍实现创建文件对teacher的h和cpp文件进行处理对student的h和cpp文件进行处理对widget的h和cpp文件进行处理 介绍 Qt中的信号和槽是一种强大的机制&#xff0c;用于处理对象之间的通信。它们是Qt框架中实现事件驱动编程的核心部分。 信号&#xff08;Signal&#x…

vite4项目中,vant兼容750适配

一般非vite项目&#xff0c;使用postcss-px-to-viewport。在设计稿为750时候&#xff0c;可使用以下配置兼容vant。 在vite4项目中&#xff0c;以上配置不行。需要调整下&#xff0c;使用postcss-px-to-viewport-8-plugin&#xff0c;并修改viewportWidth&#xff0c;具体如下…

51单片机定时/计数器相关知识点

51单片机定时/计数器相关知识点 结构组成 51单片机的定时/计数器中有两个寄存器&#xff1a; T0&#xff1a;低位&#xff1a;TL0&#xff08;字节地址8AH&#xff09;高位&#xff1a;TH0&#xff08;字节地址8CH&#xff09;T1&#xff1a;低位&#xff1a;TL1&#xff08…