插入算法(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;
}
相关推荐
鱼跃鹰飞1 分钟前
Leetcode尊享面试100题:252. 会议室
算法·leetcode·面试
程序员-King.2 分钟前
二分查找——算法总结与教学指南
数据结构·算法
J_liaty3 分钟前
Java工程师的JVM入门教程:从零理解Java虚拟机
java·开发语言·jvm
Zevalin爱灰灰4 分钟前
现代控制理论——第三章 线性控制系统的能控性和能观性
线性代数·算法·现代控制
kklovecode6 分钟前
C语言之头文件,宏和条件编译
c语言·开发语言·算法
txinyu的博客6 分钟前
Linux 内存管理
linux·运维·开发语言·c++
m0_7482523810 分钟前
Ruby 数据类型概述
开发语言·mysql·ruby
天天睡大觉13 分钟前
Python学习9
开发语言·python·学习
2301_7973122614 分钟前
学习Java39天
开发语言·python·学习
Xの哲學17 分钟前
Linux自旋锁深度解析: 从设计思想到实战应用
linux·服务器·网络·数据结构·算法