| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 318 人关注过本帖
标题:模仿newdos版主的哈希算法,不知道对否,还请各位指点一二(这次是交集了)
只看楼主 加入收藏
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
结帖率:99.76%
收藏
已结贴  问题点数:20 回复次数:3 
模仿newdos版主的哈希算法,不知道对否,还请各位指点一二(这次是交集了)
程序代码:
#include
/*
求2个数组的交集
按题目要求,需要将结果保存到令一个数组中
我直接输出到屏幕了
*/
struct Count
{
    int c;
    int count;
};

int main(void)
{
    int s1[6]={10,2,3,4,5,6};
    int s2[6]={2,3,4,12,20,8};
    struct Count conter[100];
    for(int i = 0; i < 100; i++)
    {
        conter[i].c =  i;
        conter[i].count = 0;
    }
    for(i =0; i < 6 ; i ++)
    {
        conter[s1[i]].count ++;
        conter[s2[i]].count ++;
    }
    for(i = 0; i < 100; i++)
    {
        if( conter[i].count>1 )
        {
            printf("%4d",i);
        }
    }
    return 0;
}


[ 本帖最后由 wp231957 于 2012-11-14 21:49 编辑 ]
搜索更多相关主题的帖子: color count 
2012-11-14 21:29
浅唱我的Time
Rank: 7Rank: 7Rank: 7
等 级:黑侠
帖 子:98
专家分:562
注 册:2012-9-24
收藏
得分:10 
回复 楼主 wp231957
#include<stdio.h>
/*
求2个数组的交集
按题目要求,需要将结果保存到令一个数组中
我直接输出到屏幕了
*/
struct Count
{
    int c;
    int count;
};

int main(void)
{
    int s1[6]={10,2,3,4,5,6};
    int s2[6]={2,3,4,12,20,8};
    struct Count conter[100];
    int i;
    for( i = 0; i < 100; i++)
    {
        conter[i].c =  i;
        conter[i].count = 0;
    }
    for(i =0; i < 6 ; i ++)
    {
        conter[s1[i]].count ++;
        conter[s2[i]].count ++;
    }
    for(i = 0; i < 100; i++)
    {
        if( conter[i].count )
        {
            printf("%4d",i);
        }
    }
    return 0;
}
   用vc编译的,源代码会出错,稍改了一下,貌似是求二个数组的并集,并从小到大输出
2012-11-14 21:39
wp231957
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:神界
等 级:贵宾
威 望:423
帖 子:13688
专家分:53332
注 册:2012-10-18
收藏
得分:0 
那我做错了  交集是求公共部分

DO IT YOURSELF !
2012-11-14 21:44
beyondyf
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:103
帖 子:3282
专家分:12654
注 册:2008-1-21
收藏
得分:10 
说这是哈希算法倒也不算错,毕竟这也算是键与值的对应关系,算是通过映射表吧。

但这个哈希函数的能力太过有限了。如果元素的值很大(比如数十亿,开这么大个数组不太合适吧?),数量相对少些(几百几千这个量级),你将怎么做?

哈希算法学的是根据实际需要如何设计哈希函数及解决碰撞问题。hash对你这个问题的应用效果其实并不是很大。

重剑无锋,大巧不工
2012-11-14 21:58
快速回复:模仿newdos版主的哈希算法,不知道对否,还请各位指点一二(这次是交集 ...
数据加载中...
 
   



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

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