数组合并小程序

思路:

1. 如果比插入的数组大,那么往后插入,如果继续有大的,就移动位置插入;

2. 遍历完所有要插入的元素;

3. 一个函数专门用于查找可以插入的位置,对于重复的数据,查找到的未知有可能是重复的,那么要跳过;

4. 一个函数专门用于插入动作,插入方法就是先整体移动位置,然后插入;

/*

这里一个一个插入是有效率问题的,为了程序简单,没有处理,如果有一批插入元素都在范围内,可以整体插入,但是实现条件会更多。

*/

#include <iostream>
#include <math.h>
#include <string>


using namespace std;
int data_array_a[MAX_ARRAY_SIZE]={1,2,3,0,0,0};
int data_array_b[MAX_ARRAY_SIZE]={2,5,6};

void insert_element(int *array_a, int pos, int *a_length, int element)
{   
    int tmp = 0;
    int i = pos+1;
    int j = *a_length;
    
    for(i = 0; i<(*a_length - pos); i++)
    {
        array_a[j] = array_a[j-1];
        j--;
    }
    (*a_length)++;
    array_a[pos] = element;
}

int find_position(int *array_a, int end_index, int element)
{
    while(array_a[end_index]>element)
    {
        end_index--;
    }
    return end_index;
}

int main()
{

    int input_a_size = 3;
    int input_b_size = 3;
    int j = input_a_size -1;
    int i = input_b_size -1;
    int pos = 0;
    int tmp = 0;
    
    while(i>=0){
        if(data_array_b[i]>data_array_a[j])
        {
            insert_element(data_array_a,j+1, &input_a_size, data_array_b[i]);
        }
        else
        {
            pos = find_position(data_array_a, j,data_array_b[i]);
            if(data_array_a[pos] != data_array_b[i])
            {
                insert_element(data_array_a, pos,&input_a_size, data_array_b[i]);   
            }
            j = pos;
        }
        i--;
    }
    while(tmp<input_a_size)
    {
        cout<<data_array_a[tmp]<<endl;
        tmp++;
    }
    return 0;
}

相关推荐

  1. 数组合并程序

    2024-03-29 06:50:04       16 阅读
  2. C语言实现的数组合并与排序程序

    2024-03-29 06:50:04       25 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-03-29 06:50:04       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-03-29 06:50:04       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-03-29 06:50:04       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-03-29 06:50:04       18 阅读

热门阅读

  1. 【WPF应用21】WPF 中的 TextBox 控件详解与示例

    2024-03-29 06:50:04       17 阅读
  2. Superset二次开发之webpack.config.js 功能模块解读

    2024-03-29 06:50:04       19 阅读
  3. 大语言模型中的强化学习与迁移学习技术

    2024-03-29 06:50:04       16 阅读
  4. PyTorch中nn.ReLU函数说明

    2024-03-29 06:50:04       19 阅读
  5. flutter 打包成web应用后怎么通过url跳转页面

    2024-03-29 06:50:04       18 阅读
  6. Flutter——用户关闭键盘后强制拉起键盘

    2024-03-29 06:50:04       19 阅读
  7. 解决 docker swarm 节点容器无法获取客户端真实IP

    2024-03-29 06:50:04       19 阅读
  8. 基于Redis实现延时任务

    2024-03-29 06:50:04       18 阅读
  9. 如何利用opencv进行图像视角角度变换

    2024-03-29 06:50:04       15 阅读