| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 5157 人关注过本帖
标题:求高人指点给定一个无序数组,元素各异,给出一个算法,使得能够找出最大的连 ...
只看楼主 加入收藏
a1004573547
Rank: 2
等 级:论坛游民
帖 子:78
专家分:25
注 册:2013-3-11
结帖率:40%
收藏
已结贴  问题点数:25 回复次数:14 
求高人指点给定一个无序数组,元素各异,给出一个算法,使得能够找出最大的连续序列的长度
给定一个无序数组,元素各异,给出一个算法,使得能够找出最大的连续序列的长度,比如数组[100,4,2,3,1],返回的是[1,2,3,4]的长度4,时间为O(n)
[4,7,5,9,8]连续的串就是2
【1,100,5,4,2,3】是4
7 3 2 4 6 5答案是6
搜索更多相关主题的帖子: 最大的 元素 
2013-04-08 21:34
a1004573547
Rank: 2
等 级:论坛游民
帖 子:78
专家分:25
注 册:2013-3-11
收藏
得分:0 
我也不知道O(n)行不行    谁可以证明下行不通也行
这个题时别人给我的
2013-04-08 21:40
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:3 
7 3 2 4 6 5答案是6   表示不懂

DO IT YOURSELF !
2013-04-08 22:22
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:3 
数据有木有范围呢?

开一个足够大的数组 tmp[SIZE]

然后扫描数组,把 tmp[n] 置 1

在扫描tmp,中间加判断之类的东东,求出 1出现连续的最大值

就是 O(n)复杂度了


[fly]存在即是合理[/fly]
2013-04-08 22:37
邓士林
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:淮河河畔
等 级:贵宾
威 望:61
帖 子:2392
专家分:13384
注 册:2013-3-3
收藏
得分:3 
【1,100,5,4,2,3】是4
 7 3 2 4 6 5答案是6
真心看不出来什么规律啊!让我怎么帮你解答啊

Maybe
2013-04-08 22:46
czz5242199
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:4
帖 子:660
专家分:2400
注 册:2011-10-26
收藏
得分:3 
从[4,7,5,9,8]得到的答案是2,lz的意思是不是找出的数,在给出的序列中连续,排序后刚好数值连续,即上面取出的是[9,8]?
2013-04-08 22:50
czz5242199
Rank: 11Rank: 11Rank: 11Rank: 11
等 级:小飞侠
威 望:4
帖 子:660
专家分:2400
注 册:2011-10-26
收藏
得分:0 
[3,2,1,7,4,5]的答案是3还是5?
2013-04-08 22:51
韶志
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:斗气大陆
等 级:贵宾
威 望:44
帖 子:2223
专家分:13592
注 册:2013-3-22
收藏
得分:3 
   我只能搞出最长序列的长度  既然你说是给定数组,我就直接把数组出初始化了,如果想自行输入,也比较好改
程序代码:
#include<stdio.h>
int mostrlen(int );
int main()
{
    int  a[10]={2,4,6,1,3,5,12,9,10,23},b[10],i;
  
    for(i=0;i<10;i++)
        b[i]=mostrlen(a[i]);
    for(i=1;i<10;i++)
    {
        if(b[0]<b[i])
            b[0]=b[i];
        else continue;
    }
    printf("%d\n",b[0]);
    return 0;
}

int mostrlen(int s)
{
    int a[10]={2,4,6,1,3,5,12,9,10,23},i,t=1;
loop:for(i=0;i<10;i++)
    {
        if(a[i]==s+1)
        {
            t++;
            s+=1;
            goto loop;
        }
        else continue;
    }
    return t;
}



[ 本帖最后由 韶志 于 2013-4-8 23:05 编辑 ]

三十年河东,三十年河西,莫欺少年穷!
2013-04-08 23:00
tompobing
Rank: 8Rank: 8
等 级:蝙蝠侠
帖 子:260
专家分:809
注 册:2012-12-9
收藏
得分:3 
.
2013-04-09 09:24
peach5460
Rank: 15Rank: 15Rank: 15Rank: 15Rank: 15
来 自:武汉
等 级:贵宾
威 望:30
帖 子:2780
专家分:6060
注 册:2008-1-28
收藏
得分:3 
以下是引用azzbcc在2013-4-8 22:37:40的发言:

数据有木有范围呢?

开一个足够大的数组 tmp

然后扫描数组,把 tmp[n] 置 1

在扫描tmp,中间加判断之类的东东,求出 1出现连续的最大值

就是 O(n)复杂度了

支持

不过真心感觉题目有BUG

我总觉得授人以鱼不如授人以渔...
可是总有些SB叫嚣着:要么给代码给答案,要么滚蛋...
虽然我知道不要跟SB一般见识,但是我真的没修炼到宠辱不惊...
2013-04-09 09:36
快速回复:求高人指点给定一个无序数组,元素各异,给出一个算法,使得能够找出最大 ...
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.031766 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved