从0到1搞定在线OJ

news2025/1/16 14:07:12

 目录

一、在线OJ的的原理

二、在线OJ的使用规则

三、注意事项

1.关于作弊

2.如何防止作弊

3.输入输出格式

4.换行问题

四、经典在线OJ坑人题目以及博主被坑经历

五、提交不成功及解决方法

六、如何得心应手的拿下OJ系统

七、在线OJ的骗分技巧

在线OJ(Online Judge)通常用于大学生程序设计竞赛(ACM、蓝桥杯等)、编程作业提交公司招聘选拔方法。在线OJ的正确使用对大学生非常重要!

OJ 是一个在线的判题系统。用户可以在线提交程序多种程序(如C、C++、Java、python等)源代码,系统对源代码进行编译和执行,并通过预先设计的测试数据来检验程序源代码的正确性

由于在线OJ的使用对于IT方向的大学生非常重要,且在线OJ不能手动调试代码。因此本文将对在线OJ的使用规则,原理、注意事项等进行详细的解释,最后再给出破局方法

一、在线OJ的的原理

  用户提交的程序在OJ系统下执行时将受到比较严格的限制,包括运行时间限制内存使用限制安全限制等。

  用户程序执行的结果将被OJ系统捕捉并保存,然后再转交给一个裁判程序

  该裁判程序或者比较用户程序的输出数据和标准输出样例的差别,或者检验用户程序的输出数据是否满足一定的逻辑条件。一般该裁判程序会有多组样例来检验用户程序的正确性和合理性

  最后系统返回给用户一个状态: 通过答案错误超时超过输出限制超内存运行时错误格式错误、或是无法编译,并返回程序使用的内存、运行时间等信息。

二、在线OJ的使用规则

  设置编程语言---注意时间和空间限制---写代码---自测运行---保存并提交

以牛客网(大学生校园招聘的网站)举例子  牛客网刷题

  在牛客网得到在线笔试试卷或者刷题的时候,首先要进行初始编程语言和模式设定(一般已给出),(如果公司规定了编程语言,就必须按照规定选择),如果是参与竞赛则可以自行选择拿手的编程语言

一般比较热门的编程语言都可以使用

某公司2017年的笔试编程题目

   1.此题给出了时间限制和空间限制,意味系统已经限制了此题的时间复杂度和空间复杂度,一些暴力求解的方法可能就会超出时间限制和空间限制。

  因此在做题前,一定要好好思考此题是否有更‘简单’的方法,否则就可能会落得写了很长时间的代码,最后时间复杂度太高而被迫换一种方法。

  这样会浪费大量的时间,在笔试或者竞赛中,时间是最宝贵的。

  2.此题只有C++和Java两种编程语言可以选择,这一般与公司对人才的需求有关。现在市场上公司人才需求最多的也是C++和Java方向的人才

  3.核心代码模式:就是把要处理的数据都已经放入容器里,可以直接写逻辑,侧重点是算法的逻辑,而ACM模式没有任何代码,更多的是锻炼代码能力,只要这题会做,这两种方法其实大同小异。

  在代码写好之后,使用者则可以进行‘自测运行’,自测运行会测试样例,看能否正常得出答案,自测运行可以检验代码是否有编译方面的问题,并且得到样例的预取输出和实际输出,并显示运行时间占用内存

  当自测通过后,即可进行代码提交

  当然,如果代码运行结果有问题,可能就会是多方面原因,一般系统会给出错误原因:如结果错误、内存过大、时间过长等

三、注意事项

  答题方式:Java方向类名必须是Main,且包含main函数,C++方向一定要包含main函数

1.关于作弊

千万不能作弊!!!这种线上考试一般都有防作弊监考系统,一旦被发现作弊,竞赛就会立即取消比赛资格;招聘时候的笔试也会直接被拉进黑名单,可能会永久失去进入该公司的机会

2.如何防止作弊

  1.限制切屏次数

  2.防死机、关机、掉线的人为或意外情况

  3.防使用手机,并且关闭电脑其他浏览器,QQ、微信等聊天软件

  4.防止旁边有闲杂人等

  5.保证摄像头来良好

  6.尽量使草稿纸在摄像头范围内

找工作时是人生大事,大家必须花心思认真对待,遇到重要的事,墨菲定律会放大

3.输入输出格式

  在线OJ对输入输出的格式有严格的判定,格式稍微不同(比如多一个空格),就会造成代码提交不成功

如多组输入:

//C语言
while(scanf("%d%d",&a,&b)!=EOF)
{
printf("%d\n",a+b);
}
//C++
while (cin>>a>>b)
{
cout<<a + b<< endl;
}

   后台系统会严格比对你的输出和.out 文件,每次输入输出都要谨慎

4.换行问题

  对于每个样例,建议输出完全之后都换行一下。对于一些题目,可能就是不换行就导致了后面输入数据错位,那就肯定不可能过了,每次对于自己的代码都要有一个大致的预估,才能临危不乱

四、经典在线OJ坑人题目以及博主被坑经历

  求两个数的最小公倍数,相信每个人都做过这样的题目。可就是这样的一道题,让早期博主的幼稚心灵臣服于在线OJ的淫威之下

  这是具体的题目要求

   本来以为这是一道简单的送分题,这是博主的代码:

#include<stdio.h>
int main()
{
	long long a = 0;
	long long b = 0;
	long long c = 0;
	scanf("%lld%lld", &a, &b);
	c = a;
	if (b > c)
		c = b;
	long long i = 0;
	for (i = c; i <= a * b; i++)
	{
		if (i % a == 0 && i % b == 0)
		{
			printf("%lld", i);
			break;
		}
	}
	return 0;
}

  提交了几次,刚开始是范围有问题,于是将变量都改成了long long形,最后一顿折腾下来,代码还是不通过,原因是运行时间1001ms,而题目规定的是1000ms

 当考试结束后,看了一下标准答案,震惊了

#include<stdio.h>
int main()
{
	int A = 0, B = 0;
	scanf("%d%d", &A, &B);
	int i = 1;
	while (((A * i) % B) != 0)
	{
		i++;
	}
	printf("%d\n", A * i);
	return 0;
}

  答案改进了算法的时间复杂度,当我做题的时候还在苦思冥想如何省去那1ms的时候,就已经输了

五、提交不成功及解决方法

提交不成功,一般就两种情况:

1. 代码语法问题,导致编译不同过

  a.多去刷题,将常犯的错误积累下来

  b.避免使用一些奇怪的函数,或者与平台相关的函数

  c.最好不要使用vs来写算法,vs默认是Windows下的方式,一般OJ编译器可能无法识别,并且退出使用VS也是不符合规则的

2. 代码编译成功,提交不成功

  a.查看输出不成功的信息,输出格式不对还是无法通过某个测试用例

  b.对于无法通过的测试用例,一般都会将无法通过的用例显示出来,然后提供一个本该输出与程序输出,通过 输出结果以及测试用例,检查代码那块有误。

  c.实在检查不出来,逐个测试用例处理

3. 自己编译器可以执行,但是OJ不可以通过

  如有部分同学会说,在自己的编译器上可以跑通代码,但是在OJ上面不可以提交原因是什么?这种问题有很 多种,比如传入的参数没有进行合法检查,例如:指针没有判空等等。这种问题大多是这些边界的问题。 

牛客网在线判题规则

六、如何得心应手的拿下OJ系统

1.多刷OJ题目,招聘中很多公司都会使用后OJ系统进行笔试题,刷的多了,自然就能避免很多基础性错误,如不适应编译器、编译错误的避免,提高能力才是最重要的

2.熟悉你的目标系统(Windows or Linux)

  1.这个平台下的原生系统调用 API 是怎么使用

  2.了解这个平台下的用户系统、权限控制、资源限制

3.了解你的编程语言及工具链,以及对应的规则和限制

七、在线OJ的骗分技巧

  编程题,最忌讳的就是交白卷,但是在完全没有思路的情况下,还是能拿到一点分数的

  这里还是拿博主曾经做过的一道考试题举例

这是一道稍微难一点的编程题(对刚开始的朋友而言)

1/3的用例通过,博主写了几十行代码,15分的题目得了5分。而博主在询问一些其他好友的时候,有的仅仅将样例打印了一遍就骗到了5分,这让博主情何以堪,于是我也去尝试了一下 

果然,也是1/3。 

当然可以用这种方法!

每一个看似微不足道的分数都有可能在秋招或者春招时改变你的命运,当我们面对一道大编程题的时候,如果不知道如何解答,完全可以采用这种骗分技巧,为自己争取到更多的分数!

但在我们日常学习中,还是要尽可能的提高自己能力,如果日常还用这种方法,那只能说不是骗分,而是骗自己了

如果觉得文章不错,期待你的一键三连哦,你的鼓励是我创作的动力之源,让我们一起加油,顶峰相见!!!

 在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/620020.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

管理项目-查询数据

人事管理项目-查询数据模块 后端实现配置文件实体类Dao层测试前端实现1&#xff0e;创建Dept页面2&#xff0e;修改路由3 测试 后端实现 配置文件 在application.yml文件中配置数据库连接、JPA及端口等信息&#xff0c;代码如下&#xff1a; 实体类 配置完成后建立和表结构…

“出海热”仍在持续,进军东南亚市场谁能率先突围?

在油改电的趋势下&#xff0c;伴随钠电池车型的推出&#xff0c;电动两轮车市场被进一步激活。据艾瑞咨询不完全统计与估算&#xff0c;2022年国内两轮电动车销量约5010万辆&#xff0c;较去年增长15.2%&#xff0c;预计2023年销量达到5400万辆。持续增长的销量足以说明当下的国…

JeecgBoot低代码平台 3.5.2,仪表盘版本发布!重磅新功能—支持在线拖拽设计大屏和门户

项目介绍 JeecgBoot是一款企业级的低代码平台&#xff01;前后端分离架构 SpringBoot2.x&#xff0c;SpringCloud&#xff0c;Ant Design&Vue3&#xff0c;Mybatis-plus&#xff0c;Shiro&#xff0c;JWT 支持微服务。强大的代码生成器让前后端代码一键生成! JeecgBoot引领…

北京君正案例:数传网关的集大成者—积木式边缘网关

数传网关的集大成者 USR-M300产品集成了数据的边缘采集、计算、主动上报和数据读写&#xff0c;联动控制&#xff0c;IO采集和控制等功能&#xff0c;采集协议包含标准Modbus协议和多种常见的PLC协议&#xff0c;以及行业专用协议&#xff1b;主动上报采用分组上报方式&#xf…

如何靠自学成为一名网络安全工程师?

1. 前言 说实话&#xff0c;一直到现在&#xff0c;我都认为绝大多数看我这篇文章的读者最后终究会放弃&#xff0c;原因很简单&#xff0c;自学终究是一种适合于极少数人的学习方法&#xff0c;而且非常非常慢&#xff0c;在这个过程中的变数过大&#xff0c;稍有不慎&#…

电脑提示d3dcompiler_47.dll缺失怎么修复?

d3dcompiler_47.dll是 Microsoft 的 DirectX 11 核心组件之一&#xff0c;它主要用于编译和运行 Direct3D 11 应用程序和游戏。如果您的系统中缺少这个 DLL 文件&#xff0c;可能会导致一些程序无法正常运行&#xff0c;很多游戏跟图形处理软件都会运用到。如果电脑提示“找不到…

软考A计划-系统架构师-官方考试指定教程-(1/15)

点击跳转专栏>Unity3D特效百例点击跳转专栏>案例项目实战源码点击跳转专栏>游戏脚本-辅助自动化点击跳转专栏>Android控件全解手册点击跳转专栏>Scratch编程案例 &#x1f449;关于作者 专注于Android/Unity和各种游戏开发技巧&#xff0c;以及各种资源分享&am…

Elasticsearch数据库索引及数据操作

目录结构 前言数据库初始化索引操作创建索引获取索引获取所有索引删除索引 数据操作新增POST方式PUT方式 查询主键查询全量查询search 修改全量覆盖部分修改 删除 前言 Elasticsearch安装成功情况下&#xff1b;使用Postman请求操作数据库&#xff1b;浏览器插件实现Elasticsea…

Ubuntu做深度学习+ros怎么分区

正好要重装系统了&#xff0c;学习以下怎么分区 买了铠侠rc20 &#xff0c; 1T用来做Ubuntu系统盘 整理一下要安装的东西&#xff1a; 1.要装cuda &#xff0c;6G&#xff08; 安装在 /usr/local/cuda-11.1 &#xff09; 挂载点 /usr: 存放用户程序&#xff0c;一般在/usr/…

轨道列车自动驾驶和汽车自动驾驶的区别

轨道列车自动驾驶和汽车自动驾驶在一些方面存在明显的区别&#xff0c;主要是由于它们在运行环境和技术要求上的不同。以下是一些主要区别&#xff1a; 运行环境&#xff1a;轨道列车通常在封闭的轨道系统上运行&#xff0c;与其他车辆和行人的交互相对较少。相比之下&#xf…

华为企业组网实例:VRRP+MSTP典型组网配置

华为企业组网实例&#xff1a;VRRPMSTP典型组网配置 VRRPMSTP典型组网配置实验拓扑一、VLAN配置SW3配置SW4配置 二、Trunk配置SW3配置SW4配置SW1配置SW2配置 三、链路聚合四、MSTP配置公共配置SW1配置SW2配置分别在SW3、SW4上面验证 五、VRRP配置sw1配置sw2配置 六、VRRPMSTP的…

Kafka分区消息积压排查指南

针对某个TOPIC只有几个分区积压的场景&#xff0c;可以采用以下方法进行排查&#xff1a; 消息生产是否指定key&#xff1f; 如果指定了消息key&#xff0c;那么消息会指定生产到hash(key)的分区中。如果指定了key&#xff0c;那么有下列几种可能&#xff1a; 生产该key的消息体…

决策树理论

这个文本讨论了决策树模型中的基尼系数。当数据集的所有数据属于同一类时&#xff0c;基尼系数为0&#xff0c;因为此时无需进行分类&#xff0c;已经属于同一类别。因此&#xff0c;选项B是正确的。 决策树是一种用于分类和预测的机器学习模型。基尼系数是衡量数据集纯度的指标…

Laya核心库 + 逻辑 + 资源 移植到 Vite + Vue 3 进行项目开发

Laya项目移植到Vite Vue 3 为什么写这篇文章初遇 Laya结识 Vite Vue 3Vite 构建 Vue 3 项目快速初始化项目VSCode打开项目/目录文件介绍public 目录 安装Volar扩展 导入Laya核心JS库拷贝Laya项目bin/libslibs文件夹放入Vue项目下public文件夹中 导入Laya项目逻辑拷贝Laya项目…

安装db2数据库

1.下载 安装依赖 链接&#xff1a;https://pan.baidu.com/s/1rpZn3H1oN8O0kn8YQMa-gQ?pwd8u9d 提取码&#xff1a;8u9d 需要关闭SELinux 修改配置文件vi /etc/selinux/config&#xff0c;将SELinux置为disabled&#xff0c;并重启机器。 安装缺失的32位包 从RHEL 6开始&…

正式向Win12过渡,微软为Win11开启一大波功能更新

距离 Win 11 正式发布已过去接近两年时间&#xff0c;为了让大家放弃老系统升级 Win 11&#xff0c;微软没少下功夫。 除了各种强制弹窗通知提醒升级外&#xff0c;微软还大刀阔斧砍掉 Win 10 功能更新&#xff0c;并已宣布其最后死期——2025 年 10 月。 然而这一套组合拳下…

『赠书活动 | 第十期』清华社赞助 | 《前端系列丛书》

&#x1f497;wei_shuo的个人主页 &#x1f4ab;wei_shuo的学习社区 &#x1f310;Hello World &#xff01; 『赠书活动 &#xff5c; 第十期』 本期书籍&#xff1a;《前端系列丛书》 公众号赠书&#xff1a;第二期 参与方式&#xff1a;关注公众号&#xff1a;低调而奢华 …

Dubbo快速入门 —— 基于SpringBoot Starter 开发微服务应用案例 + 知识讲解

&#x1f4a7; D u b b o 快速入门——基于 S p r i n g B o o t S t a r t e r 开发微服务应用案例 知识讲解 \color{#FF1493}{Dubbo快速入门 —— 基于SpringBoot Starter 开发微服务应用案例 知识讲解} Dubbo快速入门——基于SpringBootStarter开发微服务应用案例知识讲解…

7脚手架与jwt

1.引言 企业开发中的前端工程一般不会让程序员自己从零搭建&#xff0c;所以咱们要学会使用别人封装好的架子&#xff0c;或者低代码开发平台&#xff0c;这里 咱们快速上手一个第三方的脚手架。 参考资料 花裤衩 (panjiachen) - Gitee.com 2.安装步骤 # 克隆项目 git clon…

【HashMap】为什么用自定义的类做HashMap的Key时需要重写hashcode方法和equals方法

【HashMap】为什么用自定义的类做HashMap的Key时需要重写hashcode方法和equals方法 【一】为什么有这个问题【二】Object类的中的hashcode方法和equals方法【三】重写hashcode【四】重写equals方法【五】hashmap中使用hashcode和equals方法 【一】为什么有这个问题 因为HashMa…