顺序表应用6:有序顺序表查询
Time Limit: 7MS Memory limit: 700K
题目描述
顺序表内按照由小到大的次序存放着n个互不相同的整数(1<=n<=20000),任意输入一个整数,判断该整数在顺序表中是否存在。如果在顺序表中存在该整数,输出其在表中的序号;否则输出“No Found!"。
输入
第一行输入整数n,表示顺序表的元素个数;
第二行依次输入n个各不相同的有序整数,代表表里的元素;
第三行输入整数t,代表要查询的次数;
第四行依次输入t个整数,代表每次要查询的数值。
第二行依次输入n个各不相同的有序整数,代表表里的元素;
第三行输入整数t,代表要查询的次数;
第四行依次输入t个整数,代表每次要查询的数值。
输出
输出t行,代表t次查询的结果,如果找到在本行输出该元素在表中的位置,否则本行输出No Found!
示例输入
10 1 22 33 55 63 70 74 79 80 87 4 55 10 2 87
示例输出
4 No Found! No Found! 10
#include <stdio.h>
#include <stdlib.h>
#define max 10200
typedef struct
{
int *a;
int len;
int list;
}sq;
void init(sq &l)
{
l.a=(int *)malloc(max*sizeof(int));
l.len=0;
l.list=max;
}
void creat(sq &l,int n)
{
int i;
for(i=0;i<n;i++)
{
scanf("%d",&l.a[i]);
}
l.len=n;
}
void change(sq &l,int m)
{
int i,j,t,flag=-1;
if(m>=l.a[l.len-1])
{
flag=1;
l.a[l.len]=m;
l.len++;
}
for(i=0;i<l.len;i++)
{
if(flag==1) break;
if(m<=l.a[i])
{
t=i;
flag=0;
break;
}
}
if(flag==0)
{
for(j=l.len-1;j>=t;j--)
{
l.a[j+1]=l.a[j];
}
l.a[t]=m;
l.len++;
}
}
void dis(sq &l)
{
int i;
for(i=0;i<l.len;i++)
printf("%d ",l.a[i]);
printf("\n");
}
int main()
{
int n,m;
sq l;
init(l);
while(~scanf("%d %d",&n,&m))
{
if(m==0&&n==0) break;
creat(l,n);
change(l,m);
dis(l);
}
return 0;
}
2277

被折叠的 条评论
为什么被折叠?



