第16週OJ-ポインタ(3)


2つの秩序数列(50を超えない)に同じデータがどれだけあるかを出力し、これらのデータを出力します.
次の手順に従います.
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;
//データの読み込み
    ……
    n3 = sameNum(a,n1,b,n2,c);
    if(n3==0)
        cout<<"NULL";
    else
    {
        cout<        for(i=0; i            cout<        cout<    }
    return 0;
}
int sameNum(int *a,int n1,int *b,int n2, int *c)
{
}
入力
最初の行には、この2つのグループの数(50を超えない)を入力します.
次の2行には、この2つのグループの数を入力します.同じシーケンスの数字は繰り返されません.
しゅつりょく
1行目は同じ数字の個数を出力し、2行目は同じ数字を出力します.
同じ数字がない場合はNULLを出力します
サンプル入力
7 9 
1 3 4 6 9 12 17
2 3 6 8 10 12 15 19 21
サンプル出力
3
3 6 12
#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;
    cin>>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
"; 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 *m,*n,i=0; for(m=a;m<a+n1;m++) for(n=b;n<b+n2;n++) if(*m==*n) { i++; *c=*m; c++; } return i; }