第十六周OJ(C)——有相同数字 !

/*
 *Copyright (C) 2014,烟台大学计算机学院
 *All rights reserved.
 *文件名称 :mian.cpp
 *作    者 :韩娟
 *完成日期 :2014年12月14日
 *版 本 号 :v1.0
 *
 *问题描述 :输出两个有序数列(不超过50个)中有多少相同数据,并输出这些数据。
 *输入描述 :第一行输入这两组数的个数(不超过50个)后面两行分别输入这两组数。同一序列中的数字不会重复。
 *程序输出 :第一行输出相同数字的个数,第二行输出这些相同的数字,若没有相同的数字,输出NULL
 */
#include<iostream>
using namespace std;
int sameNum(int *a,int n1,int *b,int n2, int *c);
int main()
 {
     int a[50];
     int b[50];
     int c[50];
     int i, n1, n2, n3;
     cin>>n1>>n2;
     for(i=0;i<n1;++i)
     {
         cin>>a[i];
     }
     for(i=0;i<n2;++i)
     {
         cin>>b[i];
     }
    n3 = sameNum(a,n1,b,n2,c);
     if(n3==0)
         cout<<"NULL\n";
     else
     {
         cout<<n3<<endl;
         for(i=0; i<n3; i++)
             cout<<c[i]<<" ";
         cout<<endl;
     }
     return 0;
 }
 int sameNum(int *a,int n1,int *b,int n2, int *c)
 {

    int i,j,n3=0;
    for(i=0; i<n1; ++i)
        for(j=0; j<n2; ++j)
        {
            if(a[i]==b[j])
            {
                 c[n3]=a[i];
                n3++;
                break;
            }
        }
    return n3;

 }


知识点总结:

    感觉和上一个程序比较类似,所以可以照猫画虎,写出这个。

学习心得 :

   多多练习才能棒棒的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值