| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1517 人关注过本帖
标题:算法求最简!……
只看楼主 加入收藏
回首依依
Rank: 7Rank: 7Rank: 7
来 自:苏州
等 级:黑侠
威 望:1
帖 子:193
专家分:524
注 册:2011-12-3
结帖率:100%
收藏
已结贴  问题点数:100 回复次数:19 
算法求最简!……
求给定数列的最高频数 X (出现次数最多的数,如:{1,2,3,3,4}  X=3);现有空间复杂度O(n)的算法;想要一个O(1)的算法。

#include <stdio.h>
#include <stdlib.h>

struct Node
{
  int e,n;
  Node *next;
};
int L;
Node *A;
int X;

int main()
{
    int e;
    Node *p,*q,*r;
   
    A=NULL;
    while(scanf("%d",&L)==1)
    {
      scanf("%d",&e);
      A=(Node *)malloc(sizeof(Node));
      A->e=e;A->n=1;A->next=NULL;
      
      L--;
      while(L>0)
      {
          scanf("%d",&e);
          p=A;
          while(p!=NULL)
          {
              if(p->e==e)
              {
                  p->n++;
                  break;
              }
              q=p;p=p->next;
          }
          if(p==NULL)
          {
              r=(Node *)malloc(sizeof(Node));
              r->e=e;r->n=1;r->next=NULL;q->next=r;
          }
          L--;
      }
      
      int maxn=0;
      p=A;
      while(p!=NULL)
      {
           if((p->n)>maxn)
           {
                 maxn=p->n;X=p->e;
           }
           p=p->next;   
      }   
      printf("%d\n",X);
      
      p=A;
      while(p!=NULL)
      {
          q=p;p=p->next;
          free(q);
      }
    A=NULL;
    }
    return 0;
}
希望大家各抒己见啊……
搜索更多相关主题的帖子: 算法 include 
2012-06-06 23:43
demonleer
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:10
帖 子:483
专家分:1225
注 册:2012-6-4
收藏
得分:9 
等我下班,回去试试,百分啊好诱人~
2012-06-07 08:59
beyondyf
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:103
帖 子:3282
专家分:12654
注 册:2008-1-21
收藏
得分:0 
O(1)的算法?楼主知道O(1)是什么意思吗?

你的代码连语法错误都没排除干净,发上来有什么意义?结构体变量是那么声明的么?

重剑无锋,大巧不工
2012-06-07 09:19
lz1091914999
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:四川
等 级:贵宾
威 望:37
帖 子:2011
专家分:5959
注 册:2010-11-1
收藏
得分:9 
回复 3楼 beyondyf
可能LZ用的是C++编译器吧。

My life is brilliant
2012-06-07 09:24
回首依依
Rank: 7Rank: 7Rank: 7
来 自:苏州
等 级:黑侠
威 望:1
帖 子:193
专家分:524
注 册:2011-12-3
收藏
得分:0 
回复 4楼 lz1091914999
是的。
现在就是想要空间负责度为O(1)的算法,就是不用存储序列a中的不同元素。
2012-06-07 09:36
回首依依
Rank: 7Rank: 7Rank: 7
来 自:苏州
等 级:黑侠
威 望:1
帖 子:193
专家分:524
注 册:2011-12-3
收藏
得分:0 
回复 2楼 demonleer
写出来给你80分。。。。
2012-06-07 09:37
beyondyf
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:103
帖 子:3282
专家分:12654
注 册:2008-1-21
收藏
得分:9 
好吧,如果楼主是以C++来编译的,那我真诚的向楼主道歉。不过C++代码引用stdio.h、stdlib.h这样的头文件让我觉得很奇怪,C++中有new关键字,用起来比malloc方便得多。

重剑无锋,大巧不工
2012-06-07 09:38
回首依依
Rank: 7Rank: 7Rank: 7
来 自:苏州
等 级:黑侠
威 望:1
帖 子:193
专家分:524
注 册:2011-12-3
收藏
得分:0 
回复 7楼 beyondyf
没事,指出错误是好事啊。个人习惯不太好。。。我在c—Free上写的,C++的编译器 。
2012-06-07 09:51
beyondyf
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:103
帖 子:3282
专家分:12654
注 册:2008-1-21
收藏
得分:0 
好吧。我真的很怀疑你的要求是不是现实。如果你的输入数据不是有序的,你总是需要缓存它的。

重剑无锋,大巧不工
2012-06-07 10:01
demonleer
Rank: 9Rank: 9Rank: 9
等 级:贵宾
威 望:10
帖 子:483
专家分:1225
注 册:2012-6-4
收藏
得分:0 
如果说你的输入数列是一直增长的话,很好办到:
类似于: 1 2 3 3 4 4 4 4 4 5 7

但是你的输入是不确定的,如果我不记录下以前每个数输入的次数,那么后面的我很难判断:
类似于:1 1 2 3 3 3 3 3 1 1 1 1

有点无解
2012-06-07 10:19
快速回复:算法求最简!……
数据加载中...
 
   



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

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