【C#】螺钉和螺母问题

2023-11-06 19:30

本文主要是介绍【C#】螺钉和螺母问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

螺钉与螺母问题

做题时,遇到了这个问题,顺手记录一下。(~ ̄▽ ̄)~

问题描述

假设我们有n个直径各不相同的螺钉以及n个相应的螺母。我们一次只能比较一对螺钉和螺母,来判断螺母是大于螺钉 、小于螺钉还是正好适合螺钉。然而,我们不能拿两个螺母作比较,也不能拿两个螺钉作比较。我们的问题是要找到每一对匹配的螺钉和螺母。为该问题设计一个算法,它的平均效率必须属于集合θ(nlogn)。

思路

这个问题比较迷惑的地方就是螺母之间、螺钉之间不能比较。但说真的,螺钉是与螺母是相互对应的,螺钉与螺母比实际上就可以看做是螺母之间在比。nlogn又让人想到快排,很明显这就是是两组快排。

  1. 从螺钉中选出一个,对螺母们进行划分成三部分,比这个螺钉小的、大的和相等的。
  2. 取出第一步相等的螺母,对螺钉们进行相同的划分。
  3. 对小的部分,和大的部分,进行递归操作。

代码

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;namespace ZExercise
{ class Program{static void Swap(ref int[]a  ,int i ,int j) {int temp = a[i];a[i] = a[j];a[j] = temp;}static int Sort(ref int[] a, ref int i, ref int j, int pivot){while (i < j) //这里按照题目,是n个直径各不相同的螺钉,否则无法跳出循环{while (a[i] < pivot) { i++; }while (a[j] > pivot) { j--; } Swap(ref a, i, j);  }i++;j--;return a[i - 1];}static void Match(ref int[] nuts,ref int[] bolts,int low ,int high) {int pivot = nuts[ (low + high )/2]; int i = low;int j = high; int mbolt = Sort(ref bolts,ref i, ref j,pivot);// 利用螺母找螺钉,并划分成三部分pivot = mbolt;//用找到螺钉作为枢纽i = low;j = high;Sort(ref nuts, ref i, ref j, pivot);// 利用螺钉找螺母,并划分成三部分if (i < high) { Match(ref nuts,ref bolts,i ,high); }if (j > low) { Match(ref nuts, ref bolts, low, j); }}static void Show(int[] a,int len) {for (int i = 0; i < len; i++){Console.Write(a[i] + " ");}Console.WriteLine("");}static void Main(string[] args){int[] nuts = { 0,2,1,10,3,4,13,9,8,6};int[] bolts = { 13,4,3,2,6,10,1,9,8,0};Match(ref nuts,ref bolts,0,9);Console.WriteLine("nuts:");Show(nuts,10);Console.WriteLine("bolts:");Show(bolts, 10);Console.ReadKey();}}
}

运行结果
在这里插入图片描述

水平有限,如有错误,请多包涵 (〃‘▽’〃)

这篇关于【C#】螺钉和螺母问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)

《C#集成DeepSeek模型实现AI私有化的流程步骤(本地部署与API调用教程)》本文主要介绍了C#集成DeepSeek模型实现AI私有化的方法,包括搭建基础环境,如安装Ollama和下载DeepS... 目录前言搭建基础环境1、安装 Ollama2、下载 DeepSeek R1 模型客户端 ChatBo

springboot3.4和mybatis plus的版本问题的解决

《springboot3.4和mybatisplus的版本问题的解决》本文主要介绍了springboot3.4和mybatisplus的版本问题的解决,主要由于SpringBoot3.4与MyBat... 报错1:spring-boot-starter/3.4.0/spring-boot-starter-

在 Spring Boot 中使用异步线程时的 HttpServletRequest 复用问题记录

《在SpringBoot中使用异步线程时的HttpServletRequest复用问题记录》文章讨论了在SpringBoot中使用异步线程时,由于HttpServletRequest复用导致... 目录一、问题描述:异步线程操作导致请求复用时 Cookie 解析失败1. 场景背景2. 问题根源二、问题详细分

解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题

《解读为什么@Autowired在属性上被警告,在setter方法上不被警告问题》在Spring开发中,@Autowired注解常用于实现依赖注入,它可以应用于类的属性、构造器或setter方法上,然... 目录1. 为什么 @Autowired 在属性上被警告?1.1 隐式依赖注入1.2 IDE 的警告:

解决java.lang.NullPointerException问题(空指针异常)

《解决java.lang.NullPointerException问题(空指针异常)》本文详细介绍了Java中的NullPointerException异常及其常见原因,包括对象引用为null、数组元... 目录Java.lang.NullPointerException(空指针异常)NullPointer

Android开发中gradle下载缓慢的问题级解决方法

《Android开发中gradle下载缓慢的问题级解决方法》本文介绍了解决Android开发中Gradle下载缓慢问题的几种方法,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、网络环境优化二、Gradle版本与配置优化三、其他优化措施针对android开发中Gradle下载缓慢的问

关于Nginx跨域问题及解决方案(CORS)

《关于Nginx跨域问题及解决方案(CORS)》文章主要介绍了跨域资源共享(CORS)机制及其在现代Web开发中的重要性,通过Nginx,可以简单地解决跨域问题,适合新手学习和应用,文章详细讲解了CO... 目录一、概述二、什么是 CORS?三、常见的跨域场景四、Nginx 如何解决 CORS 问题?五、基

C# string转unicode字符的实现

《C#string转unicode字符的实现》本文主要介绍了C#string转unicode字符的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随... 目录1. 获取字符串中每个字符的 Unicode 值示例代码:输出:2. 将 Unicode 值格式化

MySQL安装时initializing database失败的问题解决

《MySQL安装时initializingdatabase失败的问题解决》本文主要介绍了MySQL安装时initializingdatabase失败的问题解决,文中通过图文介绍的非常详细,对大家的学... 目录问题页面:解决方法:问题页面:解决方法:1.勾选红框中的选项:2.将下图红框中全部改为英

Nginx启动失败:端口80被占用问题的解决方案

《Nginx启动失败:端口80被占用问题的解决方案》在Linux服务器上部署Nginx时,可能会遇到Nginx启动失败的情况,尤其是错误提示bind()to0.0.0.0:80failed,这种问题通... 目录引言问题描述问题分析解决方案1. 检查占用端口 80 的进程使用 netstat 命令使用 ss