输入数组,排序,删除相同元素,最后输出数组

关键是题目要求用不同的函数实现不同功能,孩子不会函数套用(呜呜呜),之前课被我水了……
哪位大神救救孩子
下面是具体题目:
对一维数组中存储的数据首先从小到大排序,然后删除相同元素,只保留一个,最后输出数组中的数据
样例输入 9 9 0 32 2 78 2 8 5 3 1 9 0 2 6 6 7 -1
样例输出 0 1 2 3 5 6 7 8 32 78

代码如下

#include <iostream>
using namespace std;

//冒泡排序
void bubble_sort(int a[],int n)
{
    int i,j,t;
    for (i=0;i<n-1;i++)
    {
        for (j=0;j<n-1-i;j++)
        {
            if(a[j] > a[j+1])  //从小到大,升序
            {
                t = a[j];
                a[j]=a[j+1];
                a[j+1]=t;
            }
        }
    }
}

//删除相同元素
void deleteRep(int a[],int &n)
{
    int i=0,j=0;
    int t=0;
    while(i<n)
    {
        for (j=0;j<t;j++)
        {
            if(a[j] == a[i])
                break;
        }
        if(j==t)
            a[t++] = a[i];
        i++;
    }
    n = t;
}

int main()
{
    int a[100],i,n;
    i=0;
    while(1)
    {
        cin >> a[i];
        if(a[i] == -1) break;
        i++;
    }
    n = i;
    bubble_sort(a,n);
    deleteRep(a,n);
    //显示
    for(i=0;i<n;i++)
        cout << a[i] << " ";
    return 0;
}


/* Note:Your choice is C IDE */
#include "stdio.h"

//冒泡排序
void choose(int a[10]){
    int i,j,temp;
    for(i=1;i<10;i++)
    {
        for(j=9;j>=i;j--)
        {
            if(a[j]<a[j-1]){
                temp=a[j];
                a[j]=a[j-1];
                a[j-1]=temp;
            }
        }    
    }    
}
//输出
void output(int a[10]){
    int i;
    for(i=0;i<10;i++)
        printf("%d\t",a[i]);    
}
//删除相同数据
void del(int a[10]){
    int i,j;
    for(i=0;i<10;i++)
    {
        for(j=i+1;j<10;j++)
        {
            //把相同的数据设置为0
            if(a[i]==a[j]){
                a[j]=0;    
            }
        }
    }
    //输出
    for(i=0;i<10;i++){
        if(a[i]>0)
            printf("%d\t",a[i]);    
    }
}
void main()
{
    
    int a[10];
    int i,cnt=0;
    for(i=0;i<10;i++){
        scanf("%d",&a[i]);
    }
    //冒泡排序
    choose(a);
    //输出
    output(a);
    //删除相同数据
    del(a);
}