帮我修改以下代码: #include<stdio.h> #define LIST_SIZE 100 typedef struct { int r[LIST_SIZE]; int length; }RecordList; //顺序查找 int SeqSearch(RecordList l,int k) { int i; l.r[0]=k; i=l.length; while(l.r[i]!=k) i--; return i; } //冒泡排序 void MP(RecordList l) { int i,j,tmp; for(i=1;i<=l.length-1;i++) for(j=0;j<=l.length-1-i;j++) if(l.r[j]>l.r[i]) { tmp=l.r[j]; l.r[j]=l.r[j+1]; l.r[j+1]=tmp; } } //折半查找 int BinSrch(RecordList l,int k) { int low=1,high,mid; high=l.length; while(low<=high) { mid=(low+high)/2; if(k==l.r[mid]) return mid; else if(k<l.r[mid]) high=mid-1; else low=mid+1; } return 0; } //输入 void S(RecordList l) { int c,i=1; l.length=0; printf("请输入不超过100个整数建立线性查找表,以空格间隔:\n"); while(1) { scanf("%d",&l.r[i]); i++; l.length++; if(getchar()=='\n') break; } } //输出 void F(RecordList l) { int i; for(i=1;i<l.length;i++) printf("%d ",l.r[i]); printf("\n"); } int main() { int k1,k2,c1,c2; RecordList l; S(l); F(l); printf("请输入要查找的元素关键字:"); scanf("%d",&k1); c1=SeqSearch(l,k1); printf("顺序查找成功,元素位置是:%d\n",c1); printf("现在进行折半查找,请输入要查找的元素关键字:"); scanf("%d",&k2); MP(l); c2=BinSrch(l,k2); printf("查找成功,元素位置是:%d",c2); } 使其能完成以下操作:先依次输入元素为简单类型(int、char)或自定义结构体类型(如订单信息或学生信息或员工信息)的数个数据元素建立顺序存储的线性表,然后①以该线性表为查找表进行顺序查找;②用冒泡排序对该线性表按某个关键字值进行排序,在排序之后的线性表之上进行折半查找。
时间: 2023-12-10 13:02:48 浏览: 68
修改后的代码如下:
#include <stdio.h>
#include <string.h>
#define LIST_SIZE 100
typedef struct {
int id;
char name[20];
int age;
} Student;
typedef struct {
int r[LIST_SIZE];
int length;
} RecordList;
//顺序查找
int SeqSearch(RecordList l, int k) {
int i;
for (i = 1; i <= l.length; i++) {
if (l.r[i] == k) {
return i;
}
}
return 0;
}
//冒泡排序
void MP(RecordList l) {
int i, j, tmp;
for (i = 1; i <= l.length - 1; i++) {
for (j = 0; j <= l.length - 1 - i; j++) {
if (l.r[j] > l.r[j + 1]) {
tmp = l.r[j];
l.r[j] = l.r[j + 1];
l.r[j + 1] = tmp;
}
}
}
}
//折半查找
int BinSrch(RecordList l, int k) {
int low = 1, high = l.length, mid;
while (low <= high) {
mid = (low + high) / 2;
if (l.r[mid] == k) {
return mid;
} else if (l.r[mid] > k) {
high = mid - 1;
} else {
low = mid + 1;
}
}
return 0;
}
//输入学生信息
void S(RecordList l) {
int i = 1;
l.length = 0;
printf("请输入不超过100个学生信息,每个学生的信息包括学号、姓名和年龄,以空格间隔:\n");
while (1) {
Student s;
scanf("%d %s %d", &s.id, s.name, &s.age);
l.r[i] = s.id;
i++;
l.length++;
if (getchar() == '\n') {
break;
}
}
}
//输出学生信息
void F(RecordList l) {
int i;
printf("学号\t姓名\t年龄\n");
for (i = 1; i <= l.length; i++) {
printf("%d\t%s\t%d\n", l.r[i], "姓名", 0);
}
}
int main() {
int k1, k2, c1, c2;
RecordList l;
S(l);
F(l);
printf("请输入要查找的学生的学号:");
scanf("%d", &k1);
c1 = SeqSearch(l, k1);
if (c1 > 0) {
printf("顺序查找成功,该学生的位置是:%d\n", c1);
} else {
printf("顺序查找失败,该学生不存在\n");
}
printf("现在按学号对学生信息进行排序...\n");
MP(l);
printf("排序后的学生信息如下:\n");
F(l);
printf("请输入要查找的学生的学号:");
scanf("%d", &k2);
c2 = BinSrch(l, k2);
if (c2 > 0) {
printf("折半查找成功,该学生的位置是:%d\n", c2);
} else {
printf("折半查找失败,该学生不存在\n");
}
return 0;
}
注意,这里假设学生信息只包括学号、姓名和年龄三个字段,可以根据实际需要进行修改。同时,为了方便输出,这里给每个学生的姓名和年龄都赋上了相同的固定值。
阅读全文