c语言线性查找函数,数据结构线性表查找代码c语言
c语言 最快的查找方式
1、最快的查找方式是:二分法查找。
十堰郧阳网站建设公司创新互联公司,十堰郧阳网站设计制作,有大型网站制作公司丰富经验。已为十堰郧阳成百上千提供企业网站建设服务。企业网站搭建\成都外贸网站建设要多少钱,请找那个售后服务好的十堰郧阳做网站的公司定做!
2、查找的线性表分:无序线性表、有序线性表、分块有序线性表。
3、对无序线性表只能采用顺序查找,顺序查找的平均比较次数为(n+1)/2
4、对有序线性表可以采用二分查找,二分查找的比较次数为log2n
5、对分块有序线性表可以采用分块法查找。
C语言是一种计算机程序设计语言,它既具有高级语言的特点,又具有汇编语言的特点。它由美国贝尔研究所的D.M.Ritchie于1972年推出,1978年后,C语言已先后被移植到大、中、小及微型机上,它可以作为工作系统设计语言,编写系统应用程序,也可以作为应用程序设计语言,编写不依赖计算机硬件的应用程序。它的应用范围广泛,具备很强的数据处理能力,不仅仅是在软件开发上,而且各类科研都需要用到C语言,适于编写系统软件,三维,二维图形和动画,具体应用比如单片机以及嵌入式系统开发。
数据结构 c语言实现线性表查找
表述是没有错,但是
b.elem[5]={1,2,3,4,5};
赋值能这么赋值么······,虽然elem是b的元素,但是也是个数组,数组我记得是不能这么赋值的········
其他的就没发现有啥问题了····
C语言链表操作
typedefstruct_List{intdata;struct_List*next;}List;intQuery(List**head,intx){List*p=(*head)-next;intn=1;while(pp-data!=x){p=p-next;n++;}if(p)returnn;elsereturn-1;}
c语言线性表的插入,查找和删除以电话簿为例
#includefstream.h
#includeconio.h
#includeiostream.h
#includeiomanip.h
#includestring.h
#includestdlib.h
struct friend_node//结构体类型定义,包括:姓,名,电话号码
{
char last_name[20];
char first_name[20];
char phone_num[12];
friend_node * next;
};
friend_node *head_ptr;//全程变量,链头指针
friend_node *current_ptr;//全程变量,指明位置
void handle_choice(int choice);
void add_record();
void insert_node(friend_node *new_rec_ptr);
friend_node *position_insertion_point(char lastname[20]);
void make_node_new_head(friend_node *new_rec_ptr);
void add_node_to_end(friend_node *new_rec_ptr);
void move_current_to_end();
void display_list();
void delete_record();
void delete_head_of_list();
void delete_end_of_list(friend_node *previous_ptr);
void delete_from_middle_of_list(friend_node *previous_ptr);
int verify_delete();
void delete_node(friend_node *previous_ptr);
void delete_list();
void search_by_lastname();
void write_list_to_file();
void load_list_from_file();
//void help_me();
char pause;
//main function
int main()
{
cout"欢迎使用mmc电话簿程序\nPress Enter To Continue\n";
cin.get(pause);
system("cls");
int choice;
head_ptr=NULL;
do
{
cout"1-新增\n";
cout"2-显示所有记录\n";
cout"3-通过姓来查找记录\n";
cout"4-删除记录\n";
cout"5-帮助\n";
cout"6-退出\n";
cinchoice;
handle_choice(choice);
} while(choice !=6);
return 0;
}
void handle_choice(int choice)
{
switch(choice)
{
case 1:
add_record();
break;
case 2:
display_list();
break;
case 3:
search_by_lastname();
break;
case 4:
delete_record();
break;
case 5:
cout"mmc制作\n这个程序的主要功能为:\n对电话簿的管理\n通过此程序可以实现对新增,显示,删除记录等功能\n";
break;
case 6:
write_list_to_file();
if(head_ptr !=NULL)
{
delete_list();
}
break;
default:
cout"Invalid choice\n";
break;
}
}
void add_record()
{
friend_node * new_rec_ptr;
new_rec_ptr = new friend_node;
if(new_rec_ptr !=NULL)
{
system("cls");
cin.ignore(20,'\n');
cout"First Name:";
cin.get(new_rec_ptr-first_name,15);
cin.ignore(20,'\n');
cout"last name:";
cin.get(new_rec_ptr-last_name,20);
cin.ignore(20,'\n');
cout"Phone Number: ";
cin.get(new_rec_ptr-phone_num,15);
cin.ignore(20,'\n');
insert_node(new_rec_ptr);
}
else //
{
cout"WARNING:错误,无法增加\n";
}system("cls");
}//end
//
void insert_node(friend_node * new_rec_ptr)
{
system("cls");
friend_node * before_ptr;
friend_node * after_ptr;
if(head_ptr==NULL)
{
new_rec_ptr-next=NULL;
head_ptr=new_rec_ptr;
}
else
{
if(strcmp(new_rec_ptr-last_name,head_ptr-last_name)0)
{
make_node_new_head(new_rec_ptr);
}
else
{
current_ptr=position_insertion_point(new_rec_ptr-last_name);
before_ptr=current_ptr;
after_ptr=current_ptr-next;
if(after_ptr==NULL)
{
add_node_to_end(new_rec_ptr);
}
else
{
before_ptr-next=new_rec_ptr;
new_rec_ptr-next=after_ptr;
}
}
}
}
friend_node * position_insertion_point(char lastname[20])
{//根据姓氏返回正确位置,新节点插入此点
char temp_name[20];
friend_node* temp_ptr;
int tempint;
if(head_ptr-next!=NULL)
{
current_ptr=head_ptr;
temp_ptr=current_ptr-next;
strcpy(temp_name,temp_ptr-last_name);
tempint=strcmp(lastname,temp_name);
while((tempint0)(current_ptr-next!=NULL))
{
current_ptr=temp_ptr;
if(current_ptr-next!=NULL)
{
temp_ptr=current_ptr-next;
strcpy(temp_name,temp_ptr-last_name);
tempint=strcmp(lastname,temp_name);
}
}
}
else
{
current_ptr=head_ptr;
}
return(current_ptr);
}
void make_node_new_head(friend_node * new_rec_ptr)
{
friend_node * temp_ptr;
temp_ptr=head_ptr;
new_rec_ptr-next=temp_ptr;
head_ptr=new_rec_ptr;
}
void add_node_to_end(friend_node *new_rec_ptr)
{
new_rec_ptr-next=NULL;
move_current_to_end();
current_ptr-next=new_rec_ptr;
} //
void move_current_to_end()
{
current_ptr=head_ptr;
while(current_ptr-next!=NULL)
{
current_ptr=current_ptr-next;
}
} //
//
void display_list()
{
char fullname[36];
current_ptr=head_ptr;
if(current_ptr!=NULL)
{
coutendl;
cout"Name Phone Number\n";
cout"---------------------------------------------------------\n";
do
{
strcpy(fullname," ");//
strcat(fullname,current_ptr-last_name);
strcat(fullname,", ");
strcat(fullname,current_ptr-first_name);
cout.setf(ios::left);
coutsetw(36)fullname;
cout.unsetf(ios::left);
cout.setf(ios::right);
coutsetw(12)current_ptr-phone_numendl;
current_ptr=current_ptr-next;
coutendl;
}while(current_ptr!=NULL);
cout"Press Enter to continue\n";
cin.get(pause);
cin.ignore(1,pause);
system("cls");}
else
{
cout"\n无记录显示\n";
}
}
void search_by_lastname() //根据姓名查询
{
system("cls");
char search_string[20];
current_ptr=head_ptr;
cin.ignore(20,'\n');
cout"\nEnter the last name for which you want to search:";
cin.get(search_string,20);
cin.ignore(20,'\n');
while((current_ptr!=NULL)
(strcmp(current_ptr-last_name,search_string)!=0))
{
current_ptr=current_ptr-next;
}
if(current_ptr!=NULL)
{
cout"\n记录找到\n";
coutcurrent_ptr-first_namecurrent_ptr-last_nameendl;
coutcurrent_ptr-phone_numendl;
}
else
{
cout"没有匹配记录\n";
cout"PRESS ENDTER TO CONTIUNE\n";
cin.get(pause);
system("cls");
}
} //
//
void delete_record()
{
system("cls");
char search_string[20];
friend_node *previous_ptr;
previous_ptr=NULL;
current_ptr=head_ptr;
cin.ignore(20,'\n');
cout"\nEnter the last name of the friend you want to delete:";
cin.get(search_string,20);
cin.ignore(20,'\n');
//
while((current_ptr!=NULL)(strcmp(current_ptr-last_name,search_string)!=0))
{
previous_ptr=current_ptr;
current_ptr=current_ptr-next;
}
if(current_ptr!=NULL)
{
cout"\nRECORD FOUND\n";
coutcurrent_ptr-first_namecurrent_ptr-last_nameendl;
coutcurrent_ptr-phone_numendl;
if(verify_delete())
{
delete_node(previous_ptr);
cout"\nRECORD DELETED\n";
}
else
{
cout"\nRECORD NOT DELETED\n";
}
}
else
{
cout"\nNO MATCH FOUND.NO RECORD DELETED.\n";
}
system("cls");
} //
int verify_delete()//确认删除
{
char YesNo;
cout"\nAre you sure?(Y/N)";
cinYesNo;
if((YesNo=='Y')||(YesNo=='y'))
{
return(1);
}
else
{
return(0);
}
}
void delete_node(friend_node *previous_ptr)
{
if(current_ptr==head_ptr)
{
delete_head_of_list();
}
else
{
if(current_ptr-next==NULL)
{
delete_end_of_list(previous_ptr);
}
else
{
delete_from_middle_of_list(previous_ptr);
}
}
}
void delete_head_of_list()
{
current_ptr=head_ptr;
if(head_ptr-next!=NULL)
{
head_ptr=current_ptr-next;
}
else
{
head_ptr=NULL;
}
delete current_ptr;
}
void delete_end_of_list(friend_node * previous_ptr)
{
delete current_ptr;
previous_ptr-next=NULL;
current_ptr=head_ptr;
}
void delete_from_middle_of_list(friend_node * previous_ptr)
{
previous_ptr-next=current_ptr-next;
delete current_ptr-next;
current_ptr=head_ptr;
}
void delete_list()
{
friend_node * temp_ptr;
current_ptr=head_ptr;
do
{
temp_ptr=current_ptr-next;
delete current_ptr;
current_ptr=temp_ptr;
}while(temp_ptr!=NULL);
}
void write_list_to_file()
{
ofstream outfile;
outfile.open("FRIENDS.DAT",ios::out);
if(outfile)
{
current_ptr=head_ptr;
if(head_ptr!=NULL)
{
do
{
outfilecurrent_ptr-last_nameendl;
outfilecurrent_ptr-first_nameendl;
outfilecurrent_ptr-phone_numendl;
current_ptr=current_ptr-next;
}
while(current_ptr!=NULL);
outfile"END OF FILE"endl;
outfile.close();
}
}
}
/*
std::ifstream infile;
infile.open("in.txt");
if (!infile)
return -1; //invail file
char token;
int index = 0;
while (infile)
{
infile token
node_array[index].power token
node_array[index].coeff token;
++index;
}
infile.close();
*/
C语言关于线性搜索
#include stdio.h
#include string.h
typedef struct student {
char name[30];
unsigned matrno;
}student;
student participants[] = {
{"Jonh Doe",111},
{"Bob Baumei",139},
{"Jane Smith",140},
{"Jack Archer",140},
{"Jonhnny Mahony",167},
{"Simo Anthony",170},
{"Marylin Anderson",174},
{"Melanie Thomson",181},
{"Sydney Core",183},
{"Steve Smith",186},
};
int noFstud = 10;
int linSearchByName(char name[]) {
int i;
for(i = 0; i noFstud; ++i) {
if(strcmp(name,participants[i].name) == 0)
return i;
}
return -1;
}
int main() {
char name[30];
int res;
printf("Input a name:");
res = linSearchByName(name);
if(res == -1) printf("no find.\n");
else printf("%s %u\n",participants[res].name,participants[res].matrno);
return 0;
}
c语言,输入工号,和姓名,然后线性查找,输入查找工号,输出姓名
#include"stdio.h"
#define N 10
#define Three 5
int ReadName(char name[][Three],long num[]); /*Readname()函数原型*/
int LinSearch(long num[],long x,int n); /*LinSeach()函数原型*/
int main()
{
char name[N][Three]; /*定义二维字符数组*/
int n,pos;
long num[N],x;
n=ReadName(name,num); /*输入教师姓名和工号*/
printf("Total teachers are %d\n",n);
printf("Input the searching ID");
scanf("%d",x); /*以整型格式从键盘输入待查找的工号*/
pos=LinSearch(num,x,n); /*查找工号为num的教师*/
if(pos!=-1)
printf("name = %s\n",name[pos]); /*若找到打印姓名*/
else
printf("Not found!\n"); /*若未找到,则打印未找到提示信息*/
return 0;
}
/*函数功能:输入教师的工号和姓名,当输入负值时,结束输入,返回教师人数*/
int ReadName(char name[][Three],long num[]) /*函数定义*/
{
int i=-1;
do{
i++;
printf("Input teacher's ID and name:");
scanf("%d %s",num+i,name[i]);//参数错误.
}while (num[i]0); /*输入负值时结束输入*/
return i;
}
/*按线性查找法查找值为x的数组元素,若找到则返回x在数组中的下标位置,否则返回-1*/
int LinSearch(long num[],long x,int n) /*函数定义*/
{
int i;
for (i=0;in;i++)
{
if(num[i]==x)
return i; /*若找到则返回x在数组中的下标*/
}
return -1; /*若循环结束任然未找到,则返回-1*/
}
分享标题:c语言线性查找函数,数据结构线性表查找代码c语言
网页路径:http://myzitong.com/article/dsceejp.html