插入算法(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;
}
相关推荐
深蓝轨迹几秒前
LeetCode105. 从前序与中序遍历序列构造二叉树
数据结构·算法
勇闯逆流河几秒前
【Linux】Linux基础开发工具(git、dbg)
linux·运维·服务器·开发语言·c++·git
TracyCoder1231 分钟前
LeetCode Hot100(63/100)——31. 下一个排列
数据结构·算法·leetcode
填满你的记忆3 分钟前
JVM 内存模型详解:Java 程序到底是如何运行的?
java·开发语言·jvm
222you9 分钟前
Mysql的索引以及底层的数据结构(面试)
数据结构·数据库·mysql
小温冲冲12 分钟前
C++与QML交互指南:从基础到实战
开发语言·c++·交互
不会写DN13 分钟前
Go中的泛型与any、interface有什么区别?
开发语言·后端·golang
智者知已应修善业13 分钟前
【不用第三变量交换2个数】2024-10-18
c语言·数据结构·c++·经验分享·笔记·算法
XiaoHu020716 分钟前
C/C++数据结构与算法(第三弹)
数据结构
时光の尘18 分钟前
嵌入式面试八股文(二十)·C语言关键字相关知识点速通(static、const、volatile、struct、enum、union)
c语言·const·static·union·volatile·struct·enum