朱秦乐


私信TA

用户名:dotcpp0598440

访问量:577

签 名:

等  级
排  名 12795
经  验 957
参赛次数 0
文章发表 6
年  龄 19
在职情况 学生
学  校 UFO
专  业 软件工程

  自我简介:

解题思路:该题目分为两大主要目的,第一是要对输入的数进行排序,第二是对输入的数进行筛同。排序的方法很多,仅做参考,筛同时首先利用比较将相同的数选出来,然后将相同的数进行赋值,赋值成-1,后续会利用if语句,将小于0的数删除,达到筛同的目的。

参考代码:

#include<stdio.h>
int main()
{
	int N;
	int b;
	scanf("%d", &N);
	int a[1000];
	int sum = 0;

	for (int i = 0; i < N; i++)
	{
		scanf("%d", &a[i]);
	}
	for (int i = 0;i < N; i++)
	{
		for (int j = 0; j < N - i; j++)
		{
			if (a[j] > a[j + 1])
			{
				b = a[j + 1];
				a[j + 1] = a[j];
				a[j] = b;
			}
		}
	}//排序
	for (int i = 1; i < N+1; i++)
	{
		for (int j = i + 1; j < N+1; j++)
		{
			if (a[j] == a[i])
			{
				a[i] = -1;
			}
		}
	}//把相同的数赋值成-1,方便后续的删除

	for (int i = 1; i < N+1; i++)
	{
		if (a[i] > 0)
		{
			sum = sum + 1;
		}

	}
	printf("%d\n", sum);//确定删除相同数后的个数
	for (int i = 1; i < N+1; i++)
	{
		if (a[i] > 0)
		{
			printf("%d ", a[i]);
		}

	}//打印数组

	return 0;
}


 

0.0分

2 人评分

  评论区

  • «
  • »