使用指针插入元素,在升序的数组中插入一个数,使插入后的数组仍然有序。

  • Post author:
  • Post category:其他


使用指针插入元素,在升序的数组中插入一个数,使插入后的数组仍然有序。

#include<stdio.h>
void data(int* p,int t);
int main(void)
{
	int a[10] = { 10,20,3,5,1,6,2,0,-1 };
	int Temp = 0;
	for(int i=0;i<9;i++)//冒泡法排序
		for (int j = 8; j >= i; j--)
		{
			if (a[j] < a[i])
			{
				Temp = a[j];
				a[j] = a[i];
				a[i] = Temp;
			}
		}
	printf("Array with no elements inserted:\n");
	for (int i = 0; i < 9; i++)
		printf("%d ", a[i]);
	printf("\n");
	data(a, 10);
	return 0;
}

void data(int* p, int t)//处理插叙元素
{
	int num, j;
	printf("Please enter the number you want to insert:");
	scanf_s("%d", &num);
	for (int i = 0; i < t; i++)
		if (num<*(p+i))
		{
			for (int j = t-1 ; j >= i; j--)
				*(p + j) = *(p + (j - 1));
			*(p +i) = num;
			break;//停止继续运行,防止无限赋值。
		}
	printf("Array after inserting elements:\n");
	for (int i = 0; i < t; i++)
		printf("%d ", *(p + i));
	printf("\n");
}



版权声明:本文为luck_lsj原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。