热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【每天一道PAT】1007MaximumSubsequenceSum

思路两种方法,一种方法暴力求解一种方法实时读入,当当前相加和小于0时,当前相加和更新为0。方法1求出全部最大序列和第五个测试点啊,理解有问题?不知道哪儿错了,数据为全是负数和0。希

思路

两种方法,一种方法暴力求解
一种方法实时读入,当当前相加和小于0时,当前相加和更新为0。

方法1 求出全部最大序列和
第五个测试点啊,理解有问题?不知道哪儿错了,数据为全是负数和0。希望有明白的读者加以指正。

#include
int num[10005];
int main()
{
int N;//数据个数
int this_sum=0, max_sum=0;//当前相加和、最大和
int m,n,temp;//记录子序列的左右边界下标
int count=0;//计数
scanf("%d", &N);
for (int i = 0; i {
scanf("%d",&num[i]);
if(num[i]<=0) count++;
}
if(count==N)
{
printf("0 %d %d",num[0],num[N-1]);
return 0;
}
m = n =0;
for (int i = 0; i {
this_sum = 0;
for (int j = i; j {
this_sum+=num[j];
if(this_sum >max_sum)
{
max_sum =this_sum;
n = i;
m = j;
}
}
}
printf("%d %d %d",max_sum, num[n], num[m]);
}

技术分享图片

方法2 实时处理

#include
int num[10005];
int main()
{
int N;
int this_sum=0, max_sum=0;
int m,n,temp;
int count=0;
scanf("%d", &N);
for (int i = 0; i {
scanf("%d",&num[i]);
if(num[i]<0) count++;
}
if(count==N)
{
printf("0 %d %d\n",num[0],num[N-1]);
return 0;
}
this_sum=max_sum=num[0];
m = n =0;
for (int i = 1; i {
if(this_sum <0 )
{
this_sum = 0;
temp = i;
}
this_sum += num[i];
if(this_sum >max_sum)
{
max_sum =this_sum;
n = temp;
m = i;
}
}
if(max_sum <0)
printf("0 %d %d", num[0], num[N-1]);
else
printf("%d %d %d",max_sum, num[n], num[m]);
}

技术分享图片


推荐阅读
  • malloc 是 C 语言中的一个标准库函数,全称为 memory allocation,即动态内存分配。它用于在程序运行时申请一块指定大小的连续内存区域,并返回该区域的起始地址。当无法预先确定内存的具体位置时,可以通过 malloc 动态分配内存。 ... [详细]
  • NX二次开发:UFUN点收集器UF_UI_select_point_collection详解
    本文介绍了如何在NX中使用UFUN库进行点收集器的二次开发,包括必要的头文件包含、初始化和选择点集合的具体实现。 ... [详细]
  • 本文介绍了如何在 ASP.NET 中设置 Excel 单元格格式为文本,获取多个单元格区域并作为表头,以及进行单元格合并、赋值、格式设置等操作。 ... [详细]
  • 如果应用程序经常播放密集、急促而又短暂的音效(如游戏音效)那么使用MediaPlayer显得有些不太适合了。因为MediaPlayer存在如下缺点:1)延时时间较长,且资源占用率高 ... [详细]
  • 本文介绍了一种支付平台异步风控系统的架构模型,旨在为开发类似系统的工程师提供参考。 ... [详细]
  • Python多线程详解与示例
    本文介绍了Python中的多线程编程,包括僵尸进程和孤儿进程的概念,并提供了具体的代码示例。同时,详细解释了0号进程和1号进程在系统中的作用。 ... [详细]
  • 本文详细介绍了Linux系统中用于管理IPC(Inter-Process Communication)资源的两个重要命令:ipcs和ipcrm。通过这些命令,用户可以查看和删除系统中的消息队列、共享内存和信号量。 ... [详细]
  • 解决SQL Server数据库sa登录名无法连接的问题
    在安装SQL Server数据库后,使用Windows身份验证成功,但使用SQL Server身份验证时遇到问题。本文将介绍如何通过设置sa登录名的密码、启用登录名状态以及开启TCP协议来解决这一问题。 ... [详细]
  • LDAP服务器配置与管理
    本文介绍如何通过安装和配置SSSD服务来统一管理用户账户信息,并实现其他系统的登录调用。通过图形化交互界面配置LDAP服务器,确保用户账户信息的集中管理和安全访问。 ... [详细]
  • 网络爬虫的规范与限制
    本文探讨了网络爬虫引发的问题及其解决方案,重点介绍了Robots协议的作用和使用方法,旨在为网络爬虫的合理使用提供指导。 ... [详细]
  • [c++基础]STL
    cppfig15_10.cppincludeincludeusingnamespacestd;templatevoidprintVector(constvector&integer ... [详细]
  • 自动验证时页面显示问题的解决方法
    在使用自动验证功能时,页面未能正确显示错误信息。通过使用 `dump($info->getError())` 可以帮助诊断和解决问题。 ... [详细]
  • 自定义滚动条美化页面内容
    当页面内容超出显示范围时,为了提升用户体验和页面美观,通常会添加滚动条。如果默认的浏览器滚动条无法满足设计需求,我们可以自定义一个符合要求的滚动条。本文将详细介绍自定义滚动条的实现过程。 ... [详细]
  • 本文介绍了多种开源数据库及其核心数据结构和算法,包括MySQL的B+树、MVCC和WAL,MongoDB的tokuDB和cola,boltDB的追加仅树和mmap,levelDB的LSM树,以及内存缓存中的一致性哈希。 ... [详细]
  • 零拷贝技术是提高I/O性能的重要手段,常用于Java NIO、Netty、Kafka等框架中。本文将详细解析零拷贝技术的原理及其应用。 ... [详细]
author-avatar
vghoon
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有