插入算法(C语言)

复制代码
#include<cstdio>
#include<iostream>
#define  N 9
using namespace std;
int main()
{
    int arr[N+1] = { 1,4,7,13,16,19,22,25,280 }; 
    int in,i,j;//要插入的数字
    //打印要插入数字的数组所有元素
    printf("插入前的数组: ");
    for ( i = 0; i <N; i++)
    {
	printf(" %d ", arr[i]);
    }
    //从键盘读取一个要插入的元素
    printf("\n请输入一个要插入的数:");
    scanf_s("%d", &in);
    //找插入的位置
    for (i = 0; i < N; i++)
    {
    	if (arr[i] > in)//找到位置并跳出循环
	  {
		break;
	  }
    }
    //位移,向后移
    for (j = N; j > i; j--)
    {
    	arr[j] = arr[j - i];//为要插入的数字留出位置
    }
    arr[i] = in;//将来插入的数保存在该位置
    //打印插入后的数组
    printf("\n插入后的数组:\n");
    for (i = 0; i < N+1; i++)
    {
	printf(" %d ", arr[i]);
    }
    printf("\n");
    return 0;
}
相关推荐
Coder_Boy_14 小时前
【Java核心】JVM核心知识清单
java·开发语言·jvm
wengqidaifeng14 小时前
数据结构(三)栈和队列(下)队列:程序世界的秩序之美
数据结构
努力学算法的蒟蒻14 小时前
day84(2.12)——leetcode面试经典150
算法·leetcode·面试
程序员酥皮蛋14 小时前
hot 100 第二十三题 23.反转链表
数据结构·算法·leetcode·链表
你的冰西瓜14 小时前
C++中的queue容器详解
开发语言·c++·stl
蜡笔小马14 小时前
Boost.Polygon 库概述:高效处理平面多边形几何的利器
c++·boost
TracyCoder12314 小时前
LeetCode Hot100(51/100)——155. 最小栈
数据结构·算法·leetcode
wu_asia14 小时前
每日一练叁
算法
dalong1014 小时前
A24:圈住小猫游戏
笔记·算法·游戏·aardio
Y.O.U..14 小时前
力扣刷题-86.分隔链表
算法·leetcode·链表