蓝桥杯:错误票据

错误票据【排序】

题目描述

某涉密单位下发了某种票据,并要在年终全部收回。

每张票据有唯一的 ID 号。全年所有票据的 ID 号是连续的,但 ID 的开始数码是随机选定的。

因为工作人员疏忽,在录入 ID 号的时候发生了一处错误,造成了某个 ID 断号,另外一个 ID 重号。

你的任务是通过编程,找出断号的 ID 和重号的 ID

假设断号不可能发生在最大和最小号。

输入描述

要求程序首先输入一个整数 N (N<100)表示后面数据行数。

接着读入 N 行数据。

每行数据长度不等,是用空格分开的若干个(不大于 100 个)正整数(不大于105)。

输出描述

要求程序输出 1 行,含两个整数 m,n,用空格分隔。

其中,m 表示断号 IDn 表示重号 ID

输入输出样例

示例

输入

2
5 6 8 11 9
10 12 9

输出

7 9

思路:

这道题可以有好几种思路,可以用 sort函数排序之后来寻找,也可以用标记数组统计每个 ID 出现的次数,正常出现 1 次
如果缺失在 book数组中就是 0,多于就是 2 。在输入的时候因为没给出每一行输入几个数,所以输入的时候要自己判断怎样才是结束
一行的输入。可以通过两个数之间是空格还是回车来判断,如果是回车就是表示一行的输入结束。
在输出的时候不要找到数组中是 0 或 2 立刻就输出,先定义一个变量记录下来,等遍历完了一块输出,因为有可能多余的数较小
导致先输出的数是多余的,后输出的数是缺失的。

代码:

#include<stdio.h>
int main()
{
    char c; //保存空格的,用于判断是不是输入完一行 
    int n,num;
  	int x,y;
    int min=100000,max=-100000; //寻找 ID范围 
    int book[11000]={0};  //标记数组 
    scanf("%d",&n);
    for(int i=1;i<=n;i++)
    {
        do
        {
            scanf("%d",&num);
            c=getchar(); //承接数据之间的空格 
            if(num>max) 
                max=num;
            if(num<min)
                min=num;
            book[num]++;
            
        }while(c==' '); //如果不是空格而是回车则表示一行输入结束 
    }
    for(int i=min;i<=max;i++)
    {   //遍历 ID范围内的数组 
        if(book[i]==0)
            x=i;  //缺失的 ID 
        if(book[i]>1)
            y=i;  //多余的 ID 
    }
  	printf("%d %d",x,y);
    return 0;
} 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值