{ "question_id": 1064304, "question_title": "数据合并", "question_content": "题目描述\n将两个从小到大排列的一维数组 (维长分别为 m,n , 其中 m,n≤100) 仍按从小到大的排列顺序合并到一个新的一维数组中,输出新的数组.\n输入描述\n第 1行一个正整数 m , 表示第一个要合并的一维数组中的元素个数\n第 2 行一个正整数 n , 表示第二个要合并的一维数组中的元素个数\n第 3 行输入 m 个整数 (每个数用空格分开) , 表示第一个数组元素的值.\n第 4 行输入 n 个整数 (每个数用空格分开) , 表示第二个数组元素的值.\n输出描述\n一行,表示合并后的数据,共 m +n 个数\n样例输入\n3\n4\n1 3 5\n2 4 6 8\n样例输出\n1 2 3 4 5 6 8\n要多组输入输出", "difficulty": "简单", "answer_id": 1262527, "answer_content": "\n```\n#include \nusing namespace std;\n\nvoid merge(int * a1, int m, int * a2, int n)\n{\n\tint m1 = m - 1;\n\tint n1 = n - 1;\n\tfor (int i = m + n - 1; i >= 0; i--)\n\t{\n\t\tif (m1 < 0) a1[i] = a2[n1--];\n\t\telse if (n1 < 0) a1[i] = a1[m1--];\n\t\telse if (a1[m1] < a2[n1]) a1[i] = a2[n1--];\n\t\telse a1[i] = a1[m1--];\n\t}\n}\n\nint main()\n{\n\tint m;\n\tint n;\n\tcin >> m;\n\tcin >> n;\n\tint a1[201];\n\tint a2[101];\n\tfor (int i = 0; i < m; i++) cin >> a1[i];\n\tfor (int i = 0; i < n; i++) cin >> a2[i];\n\tmerge(a1, m, a2, n);\n\tfor (int i = 0; i < m + n; i++) cout << a1[i] << \" \";\n\treturn 0;\n}\n```", "tag_name": "c++", "cpp": "#include \nusing namespace std;\nvoid merge(int * a1, int m, int * a2, int n)\n{\n\tint m1 = m - 1;\n\tint n1 = n - 1;\n\tfor (int i = m + n - 1; i >= 0; i--)\n\t{\n\t\tif (m1 < 0) a1[i] = a2[n1--];\n\t\telse if (n1 < 0) a1[i] = a1[m1--];\n\t\telse if (a1[m1] < a2[n1]) a1[i] = a2[n1--];\n\t\telse a1[i] = a1[m1--];\n\t}\n}\nint main()\n{\n\tint m;\n\tint n;\n\tcin >> m;\n\tcin >> n;\n\tint a1[201];\n\tint a2[101];\n\tfor (int i = 0; i < m; i++) cin >> a1[i];\n\tfor (int i = 0; i < n; i++) cin >> a2[i];\n\tmerge(a1, m, a2, n);\n\tfor (int i = 0; i < m + n; i++) cout << a1[i] << \" \";\n\treturn 0;\n}", "topic_link": "https://bbs.csdn.net/topics/600470263", "status": 1, "keywords": "算法初阶,排序和顺序统计量,中位数和顺序统计量", "license": "csdn.net", "notebook": { "cpp": "https://codechina.csdn.net/csdn/csdn-daily-code/-/jupyter/master/data/notebook/answer/ipynb/cpp/61.ipynb?type=file" }, "notebook_enable": 1, "author": "sinat_25061079" }