wu


私信TA

用户名:cncfvc

访问量:227228

签 名:

读研狗没有时间刷题了~~

等  级
排  名 3
经  验 37387
参赛次数 8
文章发表 265
年  龄 25
在职情况 学生
学  校 电子科技大学
专  业 通信工程

  自我简介:

写代码 真好玩 ~

这题一开始我将票据理解为xxxx+ID eg:45121(随机数)+ID(1,2,3,4....)写了很久发现这样做太难了
后来发现不是我想的那样 题目的原意就是找出断点数和重复的数 ,这样一来问题就变的很简单了
一开是输入的数字N  代表N行数据  我个人觉得它没什么用 所以只是象征性地输入了一下

接下来将数据输入到数组中 进行排序  再利用两个for循环找出断点数和重复的数字
但这其中有个陷阱 在下面的代码中 这就是为什么这题正确率这么低的原因了
#include<iostream>
#include<algorithm>
using namespace std;
int a[10006]; 
int main()
{
	//freopen("data.in.txt","r",stdin);
	int N;
	cin>>N;
	int n=0;
	while(cin>>a[n])
	{
		n++;
	}
	sort(a,a+n);
	for(int i=1;i<n;i++)
	{
		if(a[i]!=a[i-1]+1&&a[i]!=a[i-1])//注意加上限制条件a[i]!=a[i-1],否则如果重复的数在断点数之前的话就会出错
		{
		cout<<a[i]-1<<" ";
		break;
	    }
	}
	for(int i=1;i<n;i++)
	{
		if(a[i]==a[i-1])
		{
		cout<<a[i]<<endl;
		break;
	    }
	}
	return 0;
}


 

0.0分

0 人评分

  评论区

First
2017-12-04 22:10:39
  • «
  • 1
  • »