C/C++知识点之数组常见编程题
小标 2018-08-10 来源 : 阅读 1268 评论 0

摘要:本文主要向大家介绍了C/C++知识点之数组常见编程题,通过具体的内容向大家展示,希望对大家学习C/C++知识点有所帮助。

本文主要向大家介绍了C/C++知识点之数组常见编程题,通过具体的内容向大家展示,希望对大家学习C/C++知识点有所帮助。

1. 重新排列数列,使得数组左边为奇数,右边为偶数

空间复杂度O(1) 时间复杂度O(n)

思路:两个指针分别指向数组的头和尾,头指针正向遍历数组,找到第一个偶数

尾指针反向遍历数组,找到第一个奇数,两者交换

复制代码
void permu(vector& a,int& n)
{
    int i=0,j=n-1;
    while(i<j)
    {
        while(a[i]%2==1&&j>i) i+=1;
        while(a[j]%2==0&&j>i) j-=1;
        swap(a[i],a[j]);
    }
}

int main()
{
    int n;
    cin>>n;
    vector a(n,0);
    for(int i=0;i<n;i++)
    {
        cin>>a[i];
    }

    permu(a,n);
    for(int i=0;i<n;i++)
    {
        cout<<a[i]<<ends;
    }
    return 0;
}
复制代码
2. 如何找出数组中唯一的重复元素

每个数组只能访问一次,不能用辅助空间

数组a[n] 数的取值范围:1~n-1

思路:异或法,设重复的数为A,剩下的数异或的结果是B,异或的性质A^A=0 0^A=A

A^B^A^A^B=A

复制代码
int dup_elem(vector& a,int& n)
{
    int res=0;
    for(int i=0;i<n;i++)
    {
        res^=a[i];
    }
    for(int i=1;i<n;i++)
    {
        res^=i;
    }
    return res;
}

int main()
{
    int n;
    cin>>n;
    vector a(n,0);
    for(int i=0;i<n;i++)
    {
        cin>>a[i];
    }
    int res=0;
    res=dup_elem(a,n);
    cout<<res<<endl;
    return 0;
}
复制代码
 

3. 已知大小分别为m、n的两个无序数组对A、B 和一个常数c

求满足A[i]+B[j]=c的所有A[i]和B[j]

#include 
#include 
#include 
 
using namespace std;
 
void print_all_arr(vector& a,vector& b,int& m,int& n,int& sum)
{
    map mp;
    vector smaller(a);
    vector bigger(b);
    int nsmaller=(m>=n)?n:m;
    int nbigger=(m>=n)?m:n;
    if(m>n)
    {
        smaller=b;
        bigger=a;
    }
    for(int i=0;i<nsmaller;i++)
    {
        mp.insert(pair(smaller[i],true));
    }
    for(int i=0;i<nbigger;i++)
    {
        if(mp.find(sum-bigger[i])!=mp.end())
        {
            cout<<"("<<bigger[i]<<","<<sum-bigger[i]<<")"<<endl;
        }
    }
}
 
int main()
{
    int sum,m,n;
    cin>>sum>>m>>n;
    vector a(m,0);
    vector b(n,0);
    for(int i=0;i<m;i++)
    {
        cin>>a[i];
    }
    for(int i=0;i<n;i++)
    {
        cin>>b[i];
    }
    print_all_arr(a,b,m,n,sum);
 
    return 0;
}    

本文由职坐标整理并发布,了解更多内容,请关注职坐标编程语言C/C+频道!

本文由 @小标 发布于职坐标。未经许可,禁止转载。
喜欢 | 1 不喜欢 | 0
看完这篇文章有何感觉?已经有1人表态,100%的人喜欢 快给朋友分享吧~
评论(0)
后参与评论

您输入的评论内容中包含违禁敏感词

我知道了

助您圆梦职场 匹配合适岗位
验证码手机号,获得海同独家IT培训资料
选择就业方向:
人工智能物联网
大数据开发/分析
人工智能Python
Java全栈开发
WEB前端+H5

请输入正确的手机号码

请输入正确的验证码

获取验证码

您今天的短信下发次数太多了,明天再试试吧!

提交

我们会在第一时间安排职业规划师联系您!

您也可以联系我们的职业规划师咨询:

小职老师的微信号:z_zhizuobiao
小职老师的微信号:z_zhizuobiao

版权所有 职坐标-一站式AI+学习就业服务平台 沪ICP备13042190号-4
上海海同信息科技有限公司 Copyright ©2015 www.zhizuobiao.com,All Rights Reserved.
 沪公网安备 31011502005948号    

©2015 www.zhizuobiao.com All Rights Reserved