| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1517 人关注过本帖
标题:算法求最简!……
取消只看楼主 加入收藏
回首依依
Rank: 7Rank: 7Rank: 7
来 自:苏州
等 级:黑侠
威 望:1
帖 子:193
专家分:524
注 册:2011-12-3
结帖率:100%
收藏
已结贴  问题点数:100 回复次数:4 
算法求最简!……
求给定数列的最高频数 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
回首依依
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
回首依依
Rank: 7Rank: 7Rank: 7
来 自:苏州
等 级:黑侠
威 望:1
帖 子:193
专家分:524
注 册:2011-12-3
收藏
得分:0 
回复 7楼 beyondyf
没事,指出错误是好事啊。个人习惯不太好。。。我在c—Free上写的,C++的编译器 。
2012-06-07 09:51
回首依依
Rank: 7Rank: 7Rank: 7
来 自:苏州
等 级:黑侠
威 望:1
帖 子:193
专家分:524
注 册:2011-12-3
收藏
得分:0 
回复 10楼 demonleer
这是一本书上的题,我也不会。应该只有有序数列才可以吧。
其实,只要X的个数大于数列的一半就好办了;


[ 本帖最后由 回首依依 于 2012-6-7 11:10 编辑 ]
2012-06-07 10:41
快速回复:算法求最简!……
数据加载中...
 
   



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

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