IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> C语言-顺序插入 -> 正文阅读

[C++知识库]C语言-顺序插入

问题描述

【问题描述】编写程序,向有序序列中插入一个元素。设一个大小为10的一维数组中保存了一个有9个元素的非递减有序的整数序列,从键盘输入一个整数,将该整数插入到有序序列中,插入之后序列仍保持有序。输出插入前的序列和插入后的序列。

说明:有序序列通过键盘输入得到,且输入过程通过程序控制,只能输入非递减序列,若输入过程中,某元素比前一元素小,则该元素输入视为无效,需要重新输入此元素。
【输入形式】输入非递减的9个整数,输入待插整数
【输出形式】插入前的序列和插入后的序列


【样例输入】

3 3 4 5 3 7 8 10 12 15

6
【样例输出】

Before:3   3   4   5   7   8   10  12  15  

After:3   3   4   5   6   7   8   10  12  15      
【样例说明】

输入有序序列过程中,第5个整数3因小于前一个整数5,为无效输入,重新输入第5个整数为72行输入待插入整数为6

输出时,每个数据占4列列宽左对齐

解决方案

#include "stdio.h"

int main() {
    int array[10];
    int i, index = 0;
    int row2;

    /* 输入第一个数 */
    scanf("%d", &array[0]);

    /* 循环遍历输入数据,当 array[i]<array[i-1]时,重新输入数据 */
    for (i = 1; i < 9; i++) {
        do {
            scanf("%d", &array[i]);
        } while (array[i] < array[i - 1]);
    }

    /* 换行后插入的数据 */
    scanf("%d", &row2);

    printf("Before:");
    for (i = 0; i < 9; i++) {
        printf("%-4d", array[i]);
    }

    printf("\nAfter:");
    /*  将 row2 插入到 index 位置 */
    for (i = 0; i < 10; i++) {
        // 如果输入的这个数小于于数组第 i 个 元素的值时,获取数组下标
        if (row2 < array[i]) {
            index = i;
            break;
        }
    }

    // 原 index 位置以后的所数据要整体往后移
    for (i = 9; i > index; i--) {
        array[i] = array[i - 1];
    }
    // 在 index 位置将 row2 插入
    array[index] = row2;


    for (i = 0; i < 10; i++) {
        printf("%-4d", array[i]);
    }


    return 0;
}
  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-09-18 09:54:07  更:2021-09-18 09:59:56 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/23 23:19:07-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码