| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1133 人关注过本帖
标题:[求助]求有关查找的算法
只看楼主 加入收藏
蓝色雨
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2006-5-22
收藏
 问题点数:0 回复次数:10 
[求助]求有关查找的算法
1.使用链式存储结构存储,输入任意一个序列n个元素,输入一个关键字key,采用顺序查询法找 key是否在链中
2.构造一个静态顺序表(数组),输入一个有序序列存放表中,使用二分查找法查找key是否在表中.
3.把序列[10,18,3,8,12,2,7,3]构造成一个二叉排序树;中序遍历输出序列得到一个非递减序列;输入一个关键字key,查找key是否存在于树中
4.给定一个关键字序列4,5,7,2,1,3,6,试生成一棵平衡二叉树

请会的人帮我看一看````谢谢~
搜索更多相关主题的帖子: 算法 序列 二叉树 key 于树中 
2006-05-22 09:22
论坛
Rank: 3Rank: 3
等 级:新手上路
威 望:6
帖 子:1372
专家分:0
注 册:2006-3-27
收藏
得分:0 

第2个:

#include <stdio.h>
#include <conio.h>
#define N 10

static void CreateArray(int iarra[]);
static int SearchElem(int iarra[], int ikey, int ilow, int ihigh);

int main(void)
{
int iarra[N], ikey, ilow, ihigh, iindex = -1;

CreateArray(iarra);

puts("Enter found key: ");
scanf("%d", &ikey);

ilow = 0, ihigh = N - 1;

if ((iindex = SearchElem(iarra, ikey, ilow, ihigh)) != -1)
{
printf("found %d in iarra array.\n", iarra[iindex]);
}
else
{
printf("no found %d in iarra array.\n", ikey);
}

getch();
return 0;
}

static void CreateArray(int iarra[])
{
int i;

puts("Enter ten value: ");

for (i = 0; i < N; i++)
{
scanf("%d", &iarra[i]);
}
}

static int SearchElem(int iarra[], int ikey, int ilow, int ihigh)
{
int imiddle;

while (ilow <= ihigh)
{
imiddle = (ilow + ihigh) / 2;

if (iarra[imiddle] == ikey)
{
return imiddle;
}
else if (iarra[imiddle] > ikey)
{
ihigh = imiddle - 1;
}
else if (iarra[imiddle] < ikey)
{
ilow = imiddle + 1;
}
}

return -1;
}





日出东方,唯我不败! 做任何东西都是耐得住寂寞,任何一个行业要有十年以上的积累才能成为专家
2006-05-22 11:09
论坛
Rank: 3Rank: 3
等 级:新手上路
威 望:6
帖 子:1372
专家分:0
注 册:2006-3-27
收藏
得分:0 

第1个:

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

typedef struct node
{
char data;
struct node *nextPtr;
}*LinkList, Lnode;

static void CreateList(LinkList *headPtr, LinkList *tailPtr);
static void SearchElem(LinkList headPtr);

int main(void)
{
LinkList headPtr = NULL, tailPtr = NULL;

CreateList(&headPtr, &tailPtr);

SearchElem(headPtr);

getch();
return 0;
}

static void CreateList(LinkList *headPtr, LinkList *tailPtr)
{
LinkList newPtr;
int ia;

while ((ia = getchar()) != EOF)
{
if ((newPtr = (LinkList)malloc(sizeof(Lnode))) == NULL)
{
exit(1);
}
newPtr -> data = ia;
newPtr -> nextPtr = NULL;

if (*headPtr == NULL)
{
newPtr -> nextPtr = *headPtr;
*headPtr = newPtr;
}
else
{
(*tailPtr) -> nextPtr = newPtr;
}
*tailPtr = newPtr;
}
}

static void SearchElem(LinkList headPtr)
{
char ca;
int tag = 0;

printf("Enter search node: ");
fflush(stdin);
ca = getchar();

for (; headPtr != NULL; headPtr = headPtr -> nextPtr)
{
if (headPtr -> data == ca)
{
printf("found %c in linklist.\n", ca);
tag = 1;
break;
}
}

if (tag == 0)
{
printf("no found %c in linklist.\n", ca);
}
}



日出东方,唯我不败! 做任何东西都是耐得住寂寞,任何一个行业要有十年以上的积累才能成为专家
2006-05-22 11:25
论坛
Rank: 3Rank: 3
等 级:新手上路
威 望:6
帖 子:1372
专家分:0
注 册:2006-3-27
收藏
得分:0 

第3个:

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

typedef struct node
{
int data;
struct node *lchild, *rchild;
}*Tree, Tnode;

static void CreateTree(Tree *T, int ikey);
static Tree SearchKey(Tree T, int ikey);

int main(void)
{
Tree T = NULL, p = NULL;
int ikey;

while (1)
{
scanf("%d", &ikey);
if (ikey == -1)
{
break;
}

CreateTree(&T, ikey);
}

printf("Enter search key: ");
scanf("%d", &ikey);

if ((p = SearchKey(T, ikey)) != NULL)
{
printf("found %d.\n", p -> data);
}
else
{
printf("no found.\n");
}

getch();
return 0;
}

static void CreateTree(Tree *T, int ikey)
{
if (*T == NULL)
{
if (((*T) = (Tree)malloc(sizeof(Tnode))) == NULL)
{
exit(1);
}
(*T) -> data = ikey;
(*T) -> lchild = (*T) -> rchild = NULL;
}
else
{
if ((*T) -> data > ikey)
{
CreateTree(&(*T) -> lchild, ikey);
}
else if ((*T) -> data < ikey)
{
CreateTree(&(*T) -> rchild, ikey);
}
}
}

static Tree SearchKey(Tree T, int ikey)
{
Tree p = NULL;

if (T == NULL)
{
return NULL;
}
if (T -> data == ikey)
{
return T;
}
if (T -> lchild != NULL)
{
p = SearchKey(T -> lchild, ikey);
if (p != NULL)
{
return p;
}
}
if (T -> rchild != NULL)
{
p = SearchKey(T -> rchild, ikey);
if (p != NULL)
{
return p;
}
}

return NULL;
}





日出东方,唯我不败! 做任何东西都是耐得住寂寞,任何一个行业要有十年以上的积累才能成为专家
2006-05-22 11:35
论坛
Rank: 3Rank: 3
等 级:新手上路
威 望:6
帖 子:1372
专家分:0
注 册:2006-3-27
收藏
得分:0 
第4个不会

日出东方,唯我不败! 做任何东西都是耐得住寂寞,任何一个行业要有十年以上的积累才能成为专家
2006-05-22 11:35
独角龙
Rank: 1
等 级:新手上路
帖 子:221
专家分:0
注 册:2006-5-5
收藏
得分:0 

第一个:
#include <stdio.h>
#include <malloc.h>

typedef struct node
{
int data;
struct node *next;
}*LinkList, ListNode;

void CreateList(LinkList *head, LinkList *tail);
void SearchElem(LinkList head);
void VisitList(LinkList head);
void DestroyList(LinkList *head);

int main(void)
{
LinkList newhead = NULL, newtail = NULL;

CreateList(&newhead, &newtail);
VisitList(newhead);
SearchElem(newhead);

DestroyList(&newhead);

return 0;
}

void CreateList(LinkList *head, LinkList *tail)
{
int data;
LinkList p;

printf("Enter one number:\n");
scanf("%d", &data);
while (data != 0)
{
if ((p = (LinkList)malloc(sizeof(ListNode))) == NULL)
{
exit(1);
}
p -> data = data;
p -> next = NULL;

if (*head == NULL)
{
p -> next = *head;
*head = p;
}
else
{
(*tail) -> next = p;
}

*tail = p;

printf("Enter one number:\n");
scanf("%d", &data);
}
}

void SearchElem(LinkList head)
{
int key;
LinkList p;
printf("Enter the key:\n");
scanf("%d", &key);

p = head;
while (p && p -> data != key)
{
p = p -> next;
}

if (p -> data == key)
printf("The key exist in the list!\n");
else
printf("The key is not exist in the list!\n");
}

void VisitList(LinkList head)
{
while(head)
{
printf("%d ", head -> data);
head = head -> next;
}
printf("\n");
}

void DestroyList(LinkList *head)
{
LinkList temp;
while (*head != NULL)
{
temp = *head;
*head = (*head) -> next;
free(temp);
}
*head = NULL;
}


奋斗改变一切!!
2006-05-22 17:10
独角龙
Rank: 1
等 级:新手上路
帖 子:221
专家分:0
注 册:2006-5-5
收藏
得分:0 

第二个:
#include <stdio.h>
#define N 10

void CreateArray(int a[]);
int binary_search(int a[], int key, int left, int right);


int main(void)
{
int array[N], i, number;

CreateArray(array);
printf("Enter search number:\n");
scanf("%d", &number);

i = binary_search(array, number, 0, N - 1);
if (i != -1)
printf("Found key %d in the %d order in the array !", number, i);
else
printf("Not found key %d in the array!", number);

return 0;
}

void CreateArray(int a[])
{
int i;
for (i = 0; i < N; i++)
{
printf("Enter one number:\n");
scanf("%d", &a[i]);
}
}

int binary_search(int a[], int key, int left, int right)
{
int mid;
if (left <= right)
{
mid = (left + right) / 2;
if (key > a[mid])
binary_search(a, key, mid + 1, right);
else if (key < a[mid])
binary_search(a, key, left, mid - 1);
else
return mid;
}

else
return -1;

}


奋斗改变一切!!
2006-05-22 17:12
独角龙
Rank: 1
等 级:新手上路
帖 子:221
专家分:0
注 册:2006-5-5
收藏
得分:0 
三,四 不会!

奋斗改变一切!!
2006-05-22 17:13
蓝色雨
Rank: 1
等 级:新手上路
帖 子:7
专家分:0
注 册:2006-5-22
收藏
得分:0 
怎么都不会第4个啊`
2006-05-22 20:15
独角龙
Rank: 1
等 级:新手上路
帖 子:221
专家分:0
注 册:2006-5-5
收藏
得分:0 

你还是让斑竹来看看吧!


奋斗改变一切!!
2006-05-23 09:20
快速回复:[求助]求有关查找的算法
数据加载中...
 
   



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

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