老程序员分享:LOJ10155数字转换

简介: 老程序员分享:LOJ10155数字转换

"

题目描述

如果一个数 x 的约数和 y (不包括他本身)比他本身小,那么 x 可以变成 y,y 也可以变成 x。例如 4 可以变为 3,1 可以变为 7。限定所有数字变换在不超过 n 的正整数范围内进行,求不断进行数字变换且不出现重复数字的最多变换步数。

输入格式

输入一个正整数 n。

输出格式

输出不断进行数字变换且不出现重复数字的最多变换步数。

样例

样例输入

7

样例输出

3

样例说明

一种方案为 4→3→1→7。

数据范围与提示

对于 100% 的数据,1≤n≤50000。

**求树的最长链问题,先预处理每个数的约数,将可以互相转化的数之间连边,很明显这是一颗树,我们要求树的最长路径。

1 #include

2 #include

3 #include

4 #include

5 using namespace std;

6 int sum【50005】 = {0},n,d1【50005】,d2【50005】;

7 void ready()

8 {

9 int i,j;

10 scanf(""%d"",&n);

11 for(i = 1;i <= n;i++)

12 {

13 for(j = 2;j <= n / i;j++)

14 {

15 if(i * j > n)

16 break;

17 sum【i * j】 += i;

18 }

19 }

20 }

21 void dp()

22 {

23 int i;

24 for(i = n;i >= 1;i--) //因为大数字一定是小数字的后代

25 {

26 if(sum【i】 < i) //sum【i】是i的父亲节点

27 {

28 if(d1【i】 + 1 > d1【sum【i】】)//修改sum【i】这点的最大值

29 {

30 d2【sum【i】】 = d1【sum【i】】;

31 //代码效果参考:https://v.youku.com/v_show/id_XNjQwNjU4MTYzMg==.html

d1【sum【i】】 = d1【i】 + 1;

32 }

33 else if(d1【i】 + 1 >d2【sum【i】】)

34 {

35 d2【sum【i】】 = d1【i】 + 1;

36 }

37 }

38 }

39 }

40 int main()

41 {

42 int i,ans = 0;

43 ready();

44 dp();

45 for(i = 1;i <= n;i++) //遍历所有的节点,找最大值+次大值的最大值

46 {

47 if(d1【i】 + d2【i】 > ans)

48 ans = d1【i】 + //代码效果参考:https://v.youku.com/v_show/id_XNjQwNjU3MTA3Ng==.html

d2【i】;

49 }

50 printf(""%d"",ans);

51 return 0;

52 }


"
image.png
相关文章
|
C++
【周末闲谈】二进制VS三进制
【周末闲谈】二进制VS三进制
912 0
|
1天前
|
人工智能 运维 安全
|
3天前
|
SpringCloudAlibaba 负载均衡 Dubbo
微服务架构下Feign和Dubbo的性能大比拼,到底鹿死谁手?
本文对比分析了SpringCloudAlibaba框架下Feign与Dubbo的服务调用性能及差异。Feign基于HTTP协议,使用简单,适合轻量级微服务架构;Dubbo采用RPC通信,性能更优,支持丰富的服务治理功能。通过实际测试,Dubbo在调用性能、负载均衡和服务发现方面表现更出色。两者各有适用场景,可根据项目需求灵活选择。
371 123
微服务架构下Feign和Dubbo的性能大比拼,到底鹿死谁手?
|
6天前
|
人工智能 JavaScript 测试技术
Qwen3-Coder入门教程|10分钟搞定安装配置
Qwen3-Coder 挑战赛简介:无论你是编程小白还是办公达人,都能通过本教程快速上手 Qwen-Code CLI,利用 AI 轻松实现代码编写、文档处理等任务。内容涵盖 API 配置、CLI 安装及多种实用案例,助你提升效率,体验智能编码的乐趣。
581 107
|
2天前
|
Java 数据库 数据安全/隐私保护
Spring 微服务和多租户:处理多个客户端
本文介绍了如何在 Spring Boot 微服务架构中实现多租户。多租户允许单个应用实例为多个客户提供独立服务,尤其适用于 SaaS 应用。文章探讨了多租户的类型、优势与挑战,并详细说明了如何通过 Spring Boot 的灵活配置实现租户隔离、动态租户管理及数据源路由,同时确保数据安全与系统可扩展性。结合微服务的优势,开发者可以构建高效、可维护的多租户系统。
193 127
|
2天前
|
Web App开发 前端开发 API
在折叠屏应用中,如何处理不同屏幕尺寸和设备类型的样式兼容性?
在折叠屏应用中,如何处理不同屏幕尺寸和设备类型的样式兼容性?
222 124
|
2天前
|
人工智能 数据可视化 测试技术
Coze平台指南(3):核心功能-创建智能体与设计角色
Coze 智能体是由大语言模型驱动,通过提示词设定角色,并借助知识库、插件和工作流扩展能力,以执行特定任务的AI助手。对测试工程师而言,精心设计的智能体可显著提升测试效率与质量,关键是要准确理解测试需求,并将其转化为智能体的角色设定和功能配置。建议进一步学习知识库与工作流,以深化应用。

热门文章

最新文章