| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 412 人关注过本帖
标题:关于比较数组元素
只看楼主 加入收藏
Fisher~
Rank: 4
等 级:业余侠客
帖 子:93
专家分:222
注 册:2012-11-10
结帖率:100%
收藏
 问题点数:0 回复次数:5 
关于比较数组元素
怎么样能快速找到两个数组中相同元素的下标,不用双重循环时间复杂度太高
搜索更多相关主题的帖子: 怎么样 快速 元素 
2012-11-14 22:39
『点点滴滴』
Rank: 9Rank: 9Rank: 9
等 级:蜘蛛侠
帖 子:168
专家分:1035
注 册:2007-7-9
收藏
得分:0 
#include <stdio.h>

#define MAXN 1001

int main()
{
    int map[MAXN], i;   //根据需要改map的实现,只是提供一种思路
    int arrFirst[MAXN] = {2, 5, 1}, arrSecond[MAXN] = {1, 3, 5, 4};
    int arrFirstLen = 3, arrSecondLen = 4;

    for (i = 0; i < MAXN; ++i)
    {
        map[i] = -1;
    }

    for (i = 0; i < arrFirstLen; ++i)
    {
        map[arrFirst[i]] = i;
    }

    for (i = 0; i < arrSecondLen; ++i)
    {
        if (map[arrSecond[i]] != -1)
        {
            printf("posArrFirst = %d, posArrSecond = %d, val = %d\n",
                map[arrSecond[i]], i, arrSecond[i]);
        }
    }

    return 0;
}
2012-11-14 22:52
beyondyf
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:103
帖 子:3282
专家分:12654
注 册:2008-1-21
收藏
得分:0 
对元素与下标的键值对排个序。总时间复杂度也就O(N*logN)

重剑无锋,大巧不工
2012-11-14 22:52
beyondyf
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
等 级:贵宾
威 望:103
帖 子:3282
专家分:12654
注 册:2008-1-21
收藏
得分:0 
回复 2楼 『点点滴滴』
吓我一跳。一点回复怎么还出了一段代码。手快。

重剑无锋,大巧不工
2012-11-14 22:54
Fisher~
Rank: 4
等 级:业余侠客
帖 子:93
专家分:222
注 册:2012-11-10
收藏
得分:0 
回复 楼主 Fisher~
大概看懂了,明天在看看,很好的思想,明天有啥问题在来问
2012-11-15 00:26
Fisher~
Rank: 4
等 级:业余侠客
帖 子:93
专家分:222
注 册:2012-11-10
收藏
得分:0 
回复 楼主 Fisher~
实验了完全正确,方法很好很新颖谢谢了
2012-11-15 23:07
快速回复:关于比较数组元素
数据加载中...
 
   



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

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