找出作弊的人

2024-02-18 20:52
文章标签 找出 作弊

本文主要是介绍找出作弊的人,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 题目描述
  • 输入描述
  • 输出描述
  • 样例1
  • 解释:
  • 样例2
  • 代码

题目描述

公司组织了一次考试,现在考试结果出来了,想看一下有没人存在作弊行为,但是员工太多了,需要先对员工进行一次过滤,再进一步确定是否存在作弊行为。

过滤的规则为:找到分差最小的员工ID对(p1,p2)列表,要求p1<p2

员工个数取值范国:O<n<100000

员工ID为整数,取值范围:0<=n<=100000

考试成绩为整数,取值范围:0<=score<=300

输入描述

员工的ID及考试分数

输出描述

分差最小的员工ID对(p1,p2)列表,要求p1<p2。每一行代表一个集合,每个集合内的员工ID按顺序排列,多行结果也以员工对中p1值大小升序排列(如果p1相同则p2升序)。

样例1

输入:

5
1 90
2 91
3 95
4 96
5 100

输出:

1 2
3 4

解释:

输入:第一行为员工个数n,后续的n行第一个数值为员工ID,第二个数值为员工考试分数

输出:员工1和员工2的分差为1,员工3和员工4的分差也为1,因此最终结果为

1 2
3 4

样例2

输入:

5
1 90
2 91
3 92
4 85
5 86

输出:

1 2
2 3
4 5 

代码

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX 100000
// 定义结构体,用于存储员工的ID和分数
typedef struct {int id;int score;
} pairs;
// 定义比较函数,用于qsort函数对员工按照id进行排序
int cmp(const void *a, const void *b) {int id1 = ((pairs *)a)->id;int id2 = ((pairs *)b)->id;return id1 - id2;
}
int main() {int n;scanf("%d", &n);// 创建一个动态数组用于存储员工的ID和分数pairs *p = (pairs *)malloc(n * sizeof(pairs));for (int i = 0; i < n; i++) {scanf("%d %d", &p[i].id, &p[i].score);}int min = 300;for (int i = 0; i < n - 1; i++) {min = abs(p[i + 1].score - p[i].score) < min? abs(p[i + 1].score - p[i].score): min;}// 创建一个动态数组用于存储分差最小的员工ID对pairs *res = (pairs *)malloc(n * sizeof(pairs));int count = 0;for (int i = 0; i < n - 1; i++) {// 如果当前分差等于最小分差,则将当前员工ID对添加到结果动态数组中if (abs(p[i + 1].score - p[i].score) == min) {res[count].id = p[i].id;res[count].score = p[i].score;count++;}}qsort(res, count, sizeof(pairs), cmp);// 遍历排序后的员工动态数组,计算相邻员工的分差for (int i = 0; i < count; i++) {printf("%d %d\n", res[i].id, res[i].id + 1);}return 0;
}

这篇关于找出作弊的人的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/722427

相关文章

找出php中可能有问题的代码行

前言 当你发现一个平时占用cpu比较少的进程突然间占用cpu接近100%时,你如何找到导致cpu飙升的原因?我的思路是,首先找到进程正在执行的代码行,从而确定可能有问题的代码段。然后,再仔细分析有问题的代码段,从而找出原因。 如果你的程序使用的是c、c++编写,那么你可以很容易的找到正在执行的代码行。但是,程序是php编写的,如何找到可能有问题的代码行呢?这个问题就是本文要解决的问题。 背景

找出有毒的那一瓶药

找出有毒的那一瓶药 找出有毒的那一瓶药问题描述求解方法二进制编码方法详细示例 找出有毒的那一瓶药 问题描述 有47瓶药,其中只有一瓶有毒。从中毒到死亡时间为4天,问最少准备几只老鼠,在4天时间内找出有毒的药? 求解方法 要在4天内确定有毒药瓶,最少需要 6 只老鼠。以下是如何使用这 6 只老鼠来找出有毒药瓶的方法。 二进制编码方法 药瓶编号: 将47瓶药瓶编号从1到

js,找出两个数的最大公约数

/*比如说有要求a、b两个整数的最大公约数,a>b,那么我们先用a除以b,得到商8,余数r1:a÷b=q1…r1 我们当然也可以把上面这个式子改写成乘法式:a=b*q1+r1     如果r1=0,那么b就是a、b的最大公约数。 要是r1≠0,就继续除,用b除以r1,我们也可以有和上面一样的式子:b=r1*q2+r2    如果余数r2=0,那么r1就是所求的最大公约数。*/ fun

js算法题,给任意一个偶数,找出他的所有的质数因子

/*给任意一个偶数,找出他的所有的质数因子*/ function primeFactor(n){     var factors=[],            divistor=2;     if(typeof n !=='number'||!Number.isInteger(n)){          return 0;     }; //如果不是偶数返回0,如果是0,返回0

某PO手机市场竞争分析,巧用波特五力分析法找出核心竞争力!

某PO手机主要从事手机的生产与销售,最近推出了新款 Reno 系列 5G 手机。当前,苹果占据了高端市场,华为占据了中高端市场,而某 PO 手机则在剩余市场中与某 VO 和某米竞争。近年来,某 PO手机凭借中端 R 系列逐步取得市场份额。在这样的背景下,我们运用波特五力模型来分析某 PO 手机的外部环境。 1、波特五力模型案例分析:某PO手机 1.1 新进入者的威胁 由于电子产品市场竞争激烈

用来作弊的药水(快速幂)

链接: https://www.nowcoder.com/acm/contest/90/L 来源:牛客网 题目描述 在一个风雨交加的夜晚,来自异世界的不愿透露姓名的TMK同学获得了两种超强药水A、B。根据说明书,TMK知道了这两种药水的作用:     (1)药水A能使人的生命值提高,每饮用1个单位能使他生命值变成原来的x倍,即每饮用p个单位能使他的生命值变成原来的x^p(x的p

数论 - 整除问题 --- 整数集合中找出3的最大倍数

Mean:   题目描述:给一个包含非负整数的数组(长度为n),找出由这些数字组成的最大的3的倍数,没有的话则输出impossible。 analyse: 首先想到的就是直接暴力,这是最蠢的方法,数据一大的话,必会TLE。 直接用蛮力的话,生成所有的组合,为 2^n个,对每个数字再进行比较判断,需要 O(n)的时间,因为n可能会比较大,需要每个位的比较。总的时间复杂度为O(n * 2

算法/编程练习:找出若干个数使其和最接近于M

找出若干个数使其和最接近于M 1. 题目 给定一个由正数组成的列表alts,一个目标数M需要从alts中选取若干个备选数,使其和为M若找不到和刚好与M相等的备选数列表,则返回和与M最接近的备选数列表若有多个结果,返回一个即可eg1.输入: alts = [10, 9, 8, 7, 6, 5]M = 22输出: [10, 7, 5] 或 [9, 8, 5]eg2.输入: alts =

找出未出现的最小正整数

给定一个含n(n≥1)个整数的数组,找出数组中未出现的最小正整数。例如,数组{-5, 3, 2, 3}中未出现的最小正整数是1;数组{1, 2, 3}中未出现的最小正整数是4。 方法一: 思想。对数组进行快速排序,然后进行遍历数组。 ①第一个元素大于0,且不为1,则最后返回1;出现正数之前的元素为负数,且第一个正数不为1,则返回1。例如:-1,2,3;例如,2,3,4  ②现的正整数之间差

LeetCode 重构二叉搜索数,即找出两个被交换的节点

原题:Two elements of a binary search tree (BST) are swapped by mistake. Recover the tree without changing its structure. Note: A solution using O(n) space is pretty straight forward. Could you de