蓝桥杯第192题 等差数列 C++ Java Python

2024-03-23 10:20

本文主要是介绍蓝桥杯第192题 等差数列 C++ Java Python,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

题目

思路和解题方法

复杂度

        空间

        时间

c++ 代码

Java 版本(仅供参考)

Python 版本(仅供参考)


题目

思路和解题方法

  • 首先,输入n和数组a的值。
  • 对数组a进行排序。
  • 计算数组a中相邻元素之间的差的最大公约数,作为等差数列的公差。
  • 如果数组中所有元素都相等,则输出n,否则输出等差数列的项数。

复杂度

        空间

  • 对数组a进行排序的时间复杂度为O(nlogn)。
  • 计算最大公约数的时间复杂度为O(n)。
  • 整体时间复杂度为O(nlogn)。

        时间

  • 使用了一个大小为100001的长整型数组a,空间复杂度为O(n)。

c++ 代码

#include <iostream>
#include <algorithm> 
using namespace std;long long a[100001];int y(int a, int b) { // 求最大公约数的函数return b ? y(b, a % b) : a;
}int main() {int n;cin >> n; // 输入nfor (int i = 0; i < n; i++)cin >> a[i]; // 输入数组a的值sort(a, a + n); // 对数组a进行排序int d = a[1] - a[0]; // 初始等差值for (int i = 2; i < n; i++) {d = y(d, a[i] - a[i - 1]); // 计算最大公约数}if (a[n - 1] == a[0])cout << n << endl; // 如果所有元素都相等,输出nelsecout << ((a[n - 1] - a[0]) / d) + 1 << endl; // 输出等差数列的项数return 0;
}

Java 版本(仅供参考)

import java.util.*;public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);int n = scanner.nextInt();long[] a = new long[n];for (int i = 0; i < n; i++) {a[i] = scanner.nextLong();}Arrays.sort(a);long d = a[1] - a[0];for (int i = 2; i < n; i++) {d = gcd(d, a[i] - a[i - 1]);}if (a[n - 1] == a[0]) {System.out.println(n);} else {System.out.println((a[n - 1] - a[0]) / d + 1);}}private static long gcd(long a, long b) {return b == 0 ? a : gcd(b, a % b);}
}

Python 版本(仅供参考)

def gcd(a, b): # 求最大公约数return a if b == 0 else gcd(b, a % b)n = int(input())
a = list(map(int, input().split()))
a.sort() # 排序
d = a[1] - a[0]
for i in range(2, n):d = gcd(d, a[i] - a[i - 1])if a[n - 1] == a[0]:print(n)
else:print((a[n - 1] - a[0]) // d + 1)

觉得有用的话可以点点赞,支持一下。

如果愿意的话关注一下。会对你有更多的帮助。

每天都会不定时更新哦  >人<  。

这篇关于蓝桥杯第192题 等差数列 C++ Java Python的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++11范围for初始化列表auto decltype详解

《C++11范围for初始化列表autodecltype详解》C++11引入auto类型推导、decltype类型推断、统一列表初始化、范围for循环及智能指针,提升代码简洁性、类型安全与资源管理效... 目录C++11新特性1. 自动类型推导auto1.1 基本语法2. decltype3. 列表初始化3

SpringBoot监控API请求耗时的6中解决解决方案

《SpringBoot监控API请求耗时的6中解决解决方案》本文介绍SpringBoot中记录API请求耗时的6种方案,包括手动埋点、AOP切面、拦截器、Filter、事件监听、Micrometer+... 目录1. 简介2.实战案例2.1 手动记录2.2 自定义AOP记录2.3 拦截器技术2.4 使用Fi

C++11右值引用与Lambda表达式的使用

《C++11右值引用与Lambda表达式的使用》C++11引入右值引用,实现移动语义提升性能,支持资源转移与完美转发;同时引入Lambda表达式,简化匿名函数定义,通过捕获列表和参数列表灵活处理变量... 目录C++11新特性右值引用和移动语义左值 / 右值常见的左值和右值移动语义移动构造函数移动复制运算符

最新Spring Security的基于内存用户认证方式

《最新SpringSecurity的基于内存用户认证方式》本文讲解SpringSecurity内存认证配置,适用于开发、测试等场景,通过代码创建用户及权限管理,支持密码加密,虽简单但不持久化,生产环... 目录1. 前言2. 因何选择内存认证?3. 基础配置实战❶ 创建Spring Security配置文件

Python对接支付宝支付之使用AliPay实现的详细操作指南

《Python对接支付宝支付之使用AliPay实现的详细操作指南》支付宝没有提供PythonSDK,但是强大的github就有提供python-alipay-sdk,封装里很多复杂操作,使用这个我们就... 目录一、引言二、准备工作2.1 支付宝开放平台入驻与应用创建2.2 密钥生成与配置2.3 安装ali

Spring Security 单点登录与自动登录机制的实现原理

《SpringSecurity单点登录与自动登录机制的实现原理》本文探讨SpringSecurity实现单点登录(SSO)与自动登录机制,涵盖JWT跨系统认证、RememberMe持久化Token... 目录一、核心概念解析1.1 单点登录(SSO)1.2 自动登录(Remember Me)二、代码分析三、

Python获取浏览器Cookies的四种方式小结

《Python获取浏览器Cookies的四种方式小结》在进行Web应用程序测试和开发时,获取浏览器Cookies是一项重要任务,本文我们介绍四种用Python获取浏览器Cookies的方式,具有一定的... 目录什么是 Cookie?1.使用Selenium库获取浏览器Cookies2.使用浏览器开发者工具

springboot自定义注解RateLimiter限流注解技术文档详解

《springboot自定义注解RateLimiter限流注解技术文档详解》文章介绍了限流技术的概念、作用及实现方式,通过SpringAOP拦截方法、缓存存储计数器,结合注解、枚举、异常类等核心组件,... 目录什么是限流系统架构核心组件详解1. 限流注解 (@RateLimiter)2. 限流类型枚举 (

Java Thread中join方法使用举例详解

《JavaThread中join方法使用举例详解》JavaThread中join()方法主要是让调用改方法的thread完成run方法里面的东西后,在执行join()方法后面的代码,这篇文章主要介绍... 目录前言1.join()方法的定义和作用2.join()方法的三个重载版本3.join()方法的工作原

Spring AI使用tool Calling和MCP的示例详解

《SpringAI使用toolCalling和MCP的示例详解》SpringAI1.0.0.M6引入ToolCalling与MCP协议,提升AI与工具交互的扩展性与标准化,支持信息检索、行动执行等... 目录深入探索 Spring AI聊天接口示例Function CallingMCPSTDIOSSE结束语