设一顺序表中元素值递增有。编写程序,将元素x插入到表中适当的位置,并报错顺序表的有序性。用户输入顺序表个数,并赋值,保证有序;寻找插入位置;并按顺序输入元素。
代码如下:
#include<stdio.h>
int main()
{
int n; //输入顺序表容量
float x, a[100]; //x为插入元素,a[]为顺序表
float t; //t作为数值交换的中间变量
printf("请输入顺序表的大小:\n");
scanf("%d",&n);
printf("请输入%d个顺序表的值\n",n);
for(int i=0;i<n;i++){ //给表赋值
scanf("%f",&a[i]);
}
for(int i=0;i<n;i++){ //冒泡排序
for(int j=0;j<n-i-1;j++){
if(a[j]>a[j+1]){ //将大数值移到表的末尾
t = a[j];
a[j] = a[j+1];
a[j+1] = t;
}
}
}
printf("请输入插入值x的值:\n");
scanf("%f",&x);
int flag = 0; //设置标识,记录好插入下标
for(int i=0;i<n+1;i++){
if(x>a[i]){
flag = i+1; //记录下标
break; //跳出循环
}
}
for(int j=n+1;j>flag;j--){
a[j] = a[j-1]; //将flag的值向后移,空出插入x值的下标
}
a[flag] = x; //将插入值插入顺序表中
for(int i=0;i<n;i++){
printf("%f ",a[i]);
}
printf("\n插入下标为:%d",flag);
}