| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 561 人关注过本帖
标题:关于一个算法复杂性问题
只看楼主 加入收藏
hudicaca
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2006-9-16
收藏
 问题点数:0 回复次数:4 
关于一个算法复杂性问题
一个有n个整数已排列数组,设计一个O(n)时间的算法确定其中是否有这么两个数,它们的和是x
搜索更多相关主题的帖子: 算法复杂性 
2006-09-16 15:49
cwande
Rank: 2
等 级:新手上路
威 望:3
帖 子:333
专家分:0
注 册:2006-8-18
收藏
得分:0 
从两边向中间逼近,就是O(n)的了

汗,都懒得写代码了.......... cheat了一个威望,哈.....
2006-09-16 18:21
skyme
Rank: 1
等 级:新手上路
帖 子:34
专家分:0
注 册:2006-2-28
收藏
得分:0 
为什么?解释下

2006-09-16 19:47
cwande
Rank: 2
等 级:新手上路
威 望:3
帖 子:333
专家分:0
注 册:2006-8-18
收藏
得分:0 
设已有n个数a[1..n]从大到小排列,
设置两个标志j,k;令j=1,k=n;
当a[j]+a[k]>x时,j++,(使a[j]变小,因为a[k]已无法变小了)
当a[j]+a[k]<x时,k--,
当a[j]+a[k]==x或j>k时,跳出循环,
大概就是这个思路,很明显是O(n)的.......

汗,都懒得写代码了.......... cheat了一个威望,哈.....
2006-09-16 20:01
ecbtnrt
Rank: 1
等 级:新手上路
威 望:1
帖 子:189
专家分:0
注 册:2006-4-16
收藏
得分:0 

我来练练手,题目很明显一个有n个整数已排列数组
#include <iostream>
using namespace std;
int main()
{
int a[10]={0,1,2,3,4,5,6,7,8,9};
int i=0,k=9;
int x;
cout << "请输入和的值: ";
cin >> x;
while(i<k)
{
if(a[i]+a[k]==x)
{
cout << "存在这样的两个数";
return 0;
}
if(a[i]+a[k]<x)
i++;
if(a[i]+a[k]>x)
k--;
}
cout << "不存在这样的两个数。";
return 0;
}


我为你痴,为你狂!
2006-09-16 21:03
快速回复:关于一个算法复杂性问题
数据加载中...
 
   



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

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