您的位置:首页 > 其它

40-语言入门-40-C小加之随机数

2015-04-16 00:12 267 查看
题目地址: http://acm.nyist.net/JudgeOnline/problem.php?pid=255
描述

ACM队的“C小加”同学想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了N个1到1000之间的随机整数(0<N≤100),对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着不同的学生的学号。然后再把这些数从小到大排序,按照排好的顺序去找同学做调查。请你协助 C小加 完成“去重”与“排序”的工作。

输入

第一行输入整数T(1<T<10)表示多少组测试数据,

每组测试数据包括2行,

第1行为1个正整数,表示所生成的随机数的个数:N(0<N≤100)

第2行有N个用空格隔开的正整数,为所产生的随机数。

(随机数为题目给定的,不需要ACMer生成)

输出

输出也是2行,第1行为1个正整数M,表示不相同的随机数的个数。

第2行为M个用空格隔开的正整数,为从小到大排好序的不相同的随机数。

样例输入

1

10

20 40 32 67 40 20 89 300 400 15

样例输出

8

15 20 32 40 67 89 300 400

代码:

#include <stdio.h>

#include <stdlib.h>

#include <memory.h>

//定义无效值

#define INVALIDATE_DATA -1

//处理数据

static void handlerData();

//插入数据,按从大到小的顺序,且不能重复

static void insertArrBySort(int *arr,int arrLen,int inputData,int *resultCount);

//输出结果

static void printArr(int *arr,int arrLen);

int main()

{

int readLen = 0;

scanf("%d",&readLen);

getchar();

while(readLen > 0)

{

handlerData();

--readLen;

}

return 0;

}

//处理数据

static void handlerData()

{

int readLen = 0;

scanf("%d",&readLen);

getchar();

int arrLen = readLen;

int resultCount = arrLen; //记录不相同的数目

int *arr = (int*)malloc(sizeof(int)*arrLen);

memset(arr,INVALIDATE_DATA,sizeof(int)*arrLen);

while(readLen>0)

{

int inputNumber = 0;

scanf("%d",&inputNumber);

insertArrBySort(arr,arrLen,inputNumber,&resultCount);

--readLen;

}

//处理换行输入

getchar();

printf("%d\n",resultCount);

printArr(arr,arrLen);

free(arr);

}

//插入数据,按从大到小的顺序,且不能重复

static void insertArrBySort(int *arr,int arrLen,int inputData,int *resultCount)

{

int index = INVALIDATE_DATA;

int i=0;

for(;i<arrLen;++i)

{

if(arr[i] == inputData) //有重复数据不做处理

break;

if(arr[i] < inputData) //定位到存放该数据的索引位置

{

index = i;

break;

}

}

if(index != INVALIDATE_DATA && index < arrLen) //需要移动数据

{

if(arr[index] != -1)

{

i=arrLen - 1;

for(;i>index;--i)

{

arr[i] = arr[i-1];

}

}

arr[index] = inputData;

}

else

{

--(*resultCount);

}

}

//输出结果

static void printArr(int *arr,int arrLen)

{

int i=arrLen-1;

for(;i>=0;--i)

{

if(arr[i] == INVALIDATE_DATA) //有重复数据不做处理

continue;

printf("%d ",arr[i]);

}

printf("\n");

}

总结:

1.memset的第一个参数值目标指针,第二个参数是赋值内容,第三个值一定要注意,是sizeof(type)*len

2.memset需要头文件 #include <memory.h>

3.malloc需要头文件 #include <stdlib.h>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: