双向指针算法(练习)

合并有序数组

题目描述

给定两个有序整数数组nums1和nums2,将nums2合并到nums1中,使nums1成为一个有序数组

说明:初始化nums1和nums2的元素数量分别为m和n。

假设nums1有足够的空间(空间大小大于或等于m+n)来保存nums2中的元素。
输入

整数数组nums1,包含m个有效元素和足够的占位空间(通常用0填充)

整数m,表示nums1中的有效元素数量

整数数组nums2,包含n个有效元素

整数n,表示nums2中的元素数量
输出

修改后的nums1数组,包含合并后的所有元素,且保持有序

方法一:

cpp 复制代码
#include<iostream>
#include<iomanip>
#include<algorithm>
#include<string.h>
using namespace std;
int a[110];
int b[110];
int c[110];
int la,lb,lc;
int main()
{
    cin>>la;
    for(int i = 0;i<la;i++)
    {
        cin>>a[i];
    }
    cin>>lb;
    for(int i = 0;i<lb;i++)
    {
        cin>>b[i];
    }
    int i = 0;
    int j = 0;
    while(j<lb && i<la)
    {
        if(a[i]<b[j])
        {
            c[lc++] = a[i];
            i++;
        }
        else
        {
            c[lc++] = b[j];
            j++;
        }
    }
    while(i<la)
    {
        c[lc++] = a[i];
        i++;
    }
    while(j<lb)
    {
        c[lc++] = b[j];
        j++;
    }
    for(int i = 0;i<lc;i++)
    {
        cout<<c[i]<<" ";
    }
    return 0;
}

方法二:

cpp 复制代码
#include<iostream>
#include<iomanip>
#include<algorithm>
#include<string.h>
using namespace std;
int a[210];
int b[110];
int la,lb,p;
int main()
{
    cin>>la;
    for(int i = 0;i<la;i++)
    {
        cin>>a[i];
    }
    cin>>lb;
    for(int i = 0;i<lb;i++)
    {
        cin>>b[i];
    }
    int i = la;
    int j = lb;
    p = la+lb;
    while(i>=0 && j>=0)
    {
        if(a[i]>b[j]) a[p--] = a[i--];
        else a[p--] = b[j--];
    }
    for(int i = 0;i<la+lb;i++)
    {
        cout<<a[i]<<" ";
    }
    return 0;
}

完美数列

题目描述

给定一个正整数数列,和正整数p,设这个数列中的最大值是M,最小值是m,如果M≤m*p,则称这个数列是完美数列。

现在给定参数p和一些正整数,请你从中选择尽可能多的数构成一个完美数列。
输入

输入第一行给出两个正整数n和p,其中n(≤)是输入的正整数的个数,p(≤)是给定的参数。第二行给出n个正整数,每个数不超过。
输出

在一行中输出最多可以选择多少个数可以用它们组成一个完美数列

样例

样例输入

10 8

2 3 20 4 5 1 6 7 8 9

样例输出

8

cpp 复制代码
#include<iostream>
#include<iomanip>
#include<algorithm>
#include<string.h>
using namespace std;
int a[110];
int n,p;
int main()
{
    cin>>n>>p;
    for(int i = 0;i<n;i++)
    {
        cin>>a[i];
    }
    sort(a+0,a+n);
    int i = 0;
    int j = 0;
    int ma = -1;
    while(j<n)
    {
        if(a[j]<=a[i]*p)
        {
            j++;
            ma = max(ma,j-i);
        }
        else
        {
            i++;
        }
    }
    cout<<ma;
    return 0;
}
相关推荐
Wei&Yan2 分钟前
数据结构——顺序表(静/动态代码实现)
数据结构·c++·算法·visual studio code
wregjru17 分钟前
【QT】4.QWidget控件(2)
c++
浅念-22 分钟前
C++入门(2)
开发语言·c++·经验分享·笔记·学习
小羊不会打字30 分钟前
CANN 生态中的跨框架兼容桥梁:`onnx-adapter` 项目实现无缝模型迁移
c++·深度学习
Max_uuc39 分钟前
【C++ 硬核】打破嵌入式 STL 禁忌:利用 std::pmr 在“栈”上运行 std::vector
开发语言·jvm·c++
近津薪荼41 分钟前
dfs专题4——二叉树的深搜(验证二叉搜索树)
c++·学习·算法·深度优先
艾莉丝努力练剑1 小时前
【Linux:文件】Ext系列文件系统(初阶)
大数据·linux·运维·服务器·c++·人工智能·算法
Once_day2 小时前
C++之《程序员自我修养》读书总结(1)
c语言·开发语言·c++·程序员自我修养
Trouvaille ~2 小时前
【Linux】TCP Socket编程实战(一):API详解与单连接Echo Server
linux·运维·服务器·网络·c++·tcp/ip·socket
坚果派·白晓明2 小时前
在鸿蒙设备上快速验证由lycium工具快速交叉编译的C/C++三方库
c语言·c++·harmonyos·鸿蒙·编程语言·openharmony·三方库