2024-06-08:用go语言,给定三个正整数 n、x和y,

表示城市中的房屋数量以及编号为x和y的两个特殊房屋。

在这座城市中,房屋通过街道相连。对于每个编号i(1 <= i < n),

存在一条连接第i个房屋与第(i+1)个房屋的街道。

此外,还有一条特殊街道连接编号为x的房屋与编号为y的房屋。

对于每个k(1 <= k <= n),

需要找出所有满足以下条件的房屋对[house1, house2]:从house1到house2需要经过最少k条街道。

请返回一个长度为n且从下标1开始的数组result,

其中result[k]表示满足上述条件的房屋对数量,

即从一个房屋到另一个房屋需要经过最少k条街道。

注意:x和y可以相等。

输入:n = 3, x = 1, y = 3。

输出:[6,0,0]。

答案2024-06-08:

chatgpt

题目来自leetcode3017。

大体步骤如下:

1.快速检查x和y的大小关系,确保x <= y,若不满足则交换它们的值,以便后续计算更简单。

2.初始化一个长度为n的空整型数组ans,用于存储结果。

3.检查特殊情况:当x和y之间只隔一个房屋时,快速计算出ans数组的值。在这种情况下,循环遍历房屋序号,填充ans数组。

4.对于一般情况,初始化一个长度为n+1的整型数组diff,用于记录每个房屋对应的路径数量的变化。

5.定义一个匿名函数add(l, r),用于更新diff数组中的元素。该函数增加索引l到r之间的元素值。

6.使用循环遍历房屋,根据不同条件来更新diff数组中的值。具体处理逻辑如下:

  • 对于小于等于x的房屋,根据特定计算方式更新diff数组。

  • 对于大于x小于(y+x)/2的房屋,采用不同计算方式更新diff数组。

  • 其他房屋直接更新diff数组。

7.计算出所有房屋对应路径数量的变化,并填充结果数组ans。

8.返回计算结果ans。

总的时间复杂度:这段代码中的最主要操作是循环遍历房屋,即(O(n))。在每次循环中,对于不同条件,进行一些简单的数学计算和更新数组操作。因此,总的时间复杂度可以近似看作(O(n))。

总的空间复杂度:除了输入参数外,主要使用了ans、diff这两个数组来存储结果和中间计算数据,它们的长度均为n。因此,空间复杂度为(O(n))。

Go完整代码如下:

package main

import "fmt"

func countOfPairs(n, x, y int) []int64 {
if x > y {
x, y = y, x
} ans := make([]int64, n)
if x+1 >= y {
for i := 1; i < n; i++ {
ans[i-1] = int64(n-i) * 2
}
return ans
} diff := make([]int, n+1)
add := func(l, r int) {
diff[l]++
diff[r+1]--
} for i := 1; i < n; i++ {
if i <= x {
k := (x + y + 1) / 2
add(1, k-i)
add(x-i+2, x-i+y-k)
add(x-i+1, x-i+1+n-y)
} else if i < (x+y)/2 {
k := i + (y-x+1)/2
add(1, k-i)
add(i-x+2, i-x+y-k)
add(i-x+1, i-x+1+n-y)
} else {
add(1, n-i)
}
} sumD := int64(0)
for i, d := range diff[1:] {
sumD += int64(d)
ans[i] = sumD * 2
}
return ans
} func main() {
n := 3
x := 1
y := 3
fmt.Println(countOfPairs(n, x, y))
}

Python完整代码如下:

# -*-coding:utf-8-*-

def count_of_pairs(n, x, y):
if x > y:
x, y = y, x ans = [0] * n
if x + 1 >= y:
for i in range(1, n):
ans[i - 1] = (n - i) * 2
return ans diff = [0] * (n + 1) def add(l, r):
diff[l] += 1
diff[r + 1] -= 1 for i in range(1, n):
if i <= x:
k = (x + y + 1) // 2
add(1, k - i)
add(x - i + 2, x - i + y - k)
add(x - i + 1, x - i + 1 + n - y)
elif i < (x + y) // 2:
k = i + (y - x + 1) // 2
add(1, k - i)
add(i - x + 2, i - x + y - k)
add(i - x + 1, i - x + 1 + n - y)
else:
add(1, n - i) sum_d = 0
for i, d in enumerate(diff[1:], start=1):
sum_d += d
ans[i - 1] = sum_d * 2 return ans n = 3
x = 1
y = 3
print(count_of_pairs(n, x, y))

2024-06-08:用go语言,给定三个正整数 n、x和y, 表示城市中的房屋数量以及编号为x和y的两个特殊房屋。 在这座城市中,房屋通过街道相连。对于每个编号i(1 <= i < n), 存在一条的更多相关文章

  1. C#6.0语言规范(三) 基本概念

    应用程序启动 具有入口点的程序集称为应用程序.运行应用程序时,会创建一个新的应用程序域.应用程序的几个不同实例可以同时存在于同一台机器上,并且每个实例都有自己的应用程序域. 应用程序域通过充当应用程序 ...

  2. Swift5 语言参考(三) 类型

    在Swift中,有两种类型:命名类型和复合类型.一个名为类型是当它的定义可以给出一个特定名称的类型.命名类型包括类,结构,枚举和协议.例如,名为的用户定义类的实例MyClass具有该类型MyClass ...

  3. 深入研究C语言 第三篇

    本篇研究TC2.0下其他几个工具.同时看看TC由源代码到exe程序的过程. 1. 用TCC将下面的程序编为.obj文件 我们知道,TCC在默认的编译连接一个C语言的源程序a.c的时候分为以下两步: ( ...

  4. Swift语言指南(三)--语言基础之整数和浮点数

    原文:Swift语言指南(三)--语言基础之整数和浮点数 整数 整数指没有小数的整数,如42,-23.整数可以是有符号的(正数,零,负数),也可以是无符号的(正数,零). Swift提供了8,16,3 ...

  5. ASP.NET MVC:多语言的三种技术处理策略

    ASP.NET MVC:多语言的三种技术处理策略 背景 本文介绍了多语言的三种技术处理策略,每种策略对应一种场景,这三种场景是: 多语言资源信息只被.NET使用. 多语言资源信息只被Javascrip ...

  6. 基于C#程序设计语言的三种组合算法

    目录 基于C#程序设计语言的三种组合算法 1. 总体思路 1.1 前言 1.2 算法思路 1.3 算法需要注意的点 2. 三种组合算法 2.1 普通组合算法 2.2 与自身进行组合的组合算法 2.3 ...

  7. UWP 多语言的三个概念

    首先了解一下 RFC4646 和 BCP-47 是什么东西: RFC4646 The name is a combination of an ISO 639 two-letter lowercase ...

  8. TensorFlow从入门到实战资料汇总 2017-02-02 06:08 | 数据派

    TensorFlow从入门到实战资料汇总 2017-02-02 06:08 | 数据派 来源:DataCastle数据城堡 TensorFlow是谷歌基于DistBelief进行研发的第二代人工智能学 ...

  9. 关于Oracle中查询的数字值的显示格式需要保留小数点后两位(或者三位,及其他位数)

    关于Oracle中查询的数字值的显示格式需要保留小数点后两位(或者三位,及其... 方法一:使用to_char的fm格式,即: to_char(round(data.amount,2),'FM9999 ...

  10. SystemVerilog语言简介(三)

    15. 强制类型转换 Verilog不能将一个值强制转换成不同的数据类型.SystemVerilog通过使用'操作符提供了数据类型的强制转换功能.这种强制转换可以转换成任意类型,包括用户定义的类型.例 ...

随机推荐

  1. vscode设置语法错误时在文件名显示报错

  2. 【笔记】connect by中的nocycle

    connect by主要用于父子,祖孙,上下级等层级关系的查询 常用的是prior,nocycle prior: 查询父行的限定符,格式: prior column1 = column2 or col ...

  3. 平安保险基于 SPI 机制的 RocketMQ 定制化应用

    ​简介:本文讲讲述平安保险为何选择 RocketMQ,以及在确定使用消息中间件后,又是如何去选择哪款消息中间件的. 作者:孙园园|平安人寿资深开发 为什么选用 RocketMQ 首先跟大家聊聊我们为什 ...

  4. 基于链路思想的SpringBoot单元测试快速写法

    ​简介:本文更偏向实践而非方法论,所提及的SpringBoot单元测试写法亦并非官方解,仅仅是笔者自身觉得比较方便.效率较高的一种写法.每个团队甚至团队内的每位开发可能都有自己的写法习惯和风格,只要能 ...

  5. QUIC技术创新 让视频和图片分发再提速

    ​简介:在1月12日的「阿里云CDN产品发布会-新一代传输协议QUIC让CDN更快一步」之上,阿里云技术专家淮叶分享了QUIC技术及其应用落地实践,内容包含:QUIC协议介绍.相比TCP有哪些优势.应 ...

  6. 庖丁解牛-图解MySQL 8.0优化器查询转换篇

    ​简介: 在<庖丁解牛-图解MySQL 8.0优化器查询解析篇>一文中我们重点介绍了MySQL最新版本8.0.25关于SQL基本元素表.列.函数.聚合.分组.排序等元素的解析.设置和转换过 ...

  7. [GPT] AI大模型背景下,小模型还有优势吗?

      在AI大模型背景下,小的模型仍然具有一些优势. 以下是一些可能的优势: 速度和效率:相比于大模型,小模型需要更少的计算资源和时间,能够更快地完成训练和预测,并且能够在较低的硬件配置上运行. 灵活性 ...

  8. dotnet 读 WPF 源代码笔记 WriteableBitmap 的渲染和更新是如何实现

    在 WPF 框架提供方便进行像素读写的 WriteableBitmap 类,本文来告诉大家在咱写下像素到 WriteableBitmap 渲染,底层的逻辑 之前我使用 WriteableBitmap ...

  9. 理解FPGA内部的同步信号、异步信号和亚稳态

    FPGA(Field-Programmable Gate Array),即现场可编程门阵列.主要是利用内部的可编程逻辑实现设计者想要的功能.FPGA属于数字逻辑芯片,其中也有可能会集成一部分模拟电路的 ...

  10. redis-desktop-manager-0.8.0.3844

    redis-desktop-manager-0.8.0.3844 下载地址: https://www.aliyundrive.com/s/Y2fobkVjAdF 链接:https://pan.baid ...