算法竞赛数据生成及使用Sublime对拍
创始人
2024-11-15 17:37:06
0

写在前面:最近几天看蒋老师直接使用了Sublime中的FastOlympicCode插件进行了对拍,出于兴趣来学习一下,关于插件的配置已经有很多大佬讲过啦,这里不再赘述。数据生成的代码我会放到最后,包括生成数组、区间、树、图。

如何使用Sublime进行对拍

首先,如果我们需要对d.cpp这个文件进行对拍,就需要创建d__Good.cppd__Generator.cpp两个文件,顾名思义,前者是正确代码,而后者是数据生成的代码,注意两个文件中都带有两个下划线。

然后,我们在需要对拍的文件中按下ctrl+shift+p找到FastOlympicCoding:Make Stress
在这里插入图片描述
然后回车即可,下图表示程序正在编译
在这里插入图片描述
编译完成后,对拍进行过程如下图所示,找到错误数据后对拍会自动暂停。
在这里插入图片描述

如何生成数据

这里给出一份生成数据的代码,可以生成数组、区间、树、图,供大家参考。

如有错误欢迎您及时向我指出。

#include  using i64 = long long;  std::mt19937 rnd(std::chrono::steady_clock().now().time_since_epoch().count());  int rng(int l, int r) { // [l, r] 	return rnd() % (r - l + 1) + l; }  void array(int n) { // Generates an array with n elements 	int m = 1E9; 	std::vector a(n); 	for (int i = 0; i < n; i++) { 		a[i] = rng(0, m); 		std::cout << a[i] << " \n"[i == n - 1]; 	} }  void cand(int m, int n) { // Generate m cands from 1 to n 	for (int i = 0; i < m; i++) { 		int l = rng(1, n); 		int r = rng(1, n);  		if (l > r) { 			std::swap(l, r); 		}  		std::cout << l << " " << r << "\n"; 	} }  void tree(int n) { // Generate a tree with n vertices 	int m = 1E9; 	for (int i = 1; i < n; i++) { 		int p = rng(0, i - 1); 		int v = rng(1, m); 		std::cout << p + 1 << " " << i + 1 << " " << v << "\n"; 	} }  void graph(int n, int m) { // Generate an undirected graph with n vertices and m edges. There are no double edges or self-rings in the graph, and must be connected. 	std::vector> e; 	std::map, bool> f;  	std::cout << n << " " << m << "\n";  	for (int i = 1; i < n; i++) { 		int p = rng(0, i - 1); 		e.push_back(std::make_pair(p, i)); 		f[std::make_pair(p, i)] = f[std::make_pair(i, p)] = true; 	}  	// debug(f); 	for (int i = n; i <= m; i++) { 		int x, y; 		do { 			x = rng(0, n - 1); 			y = rng(0, n - 1); 		} while (x == y || f.count(std::make_pair(x, y)));  		e.push_back(std::make_pair(x, y)); 		f[std::make_pair(x, y)] = f[std::make_pair(y, x)] = true; 	}  	std::shuffle(e.begin(), e.end(), rnd);  	for (auto [x, y] : e) { 		std::cout << x + 1 << " " << y + 1 << "\n"; 	} }  int main() { 	int t = 5; 	std::cout << t << "\n";  	while (t--) { 		graph(3, 3); 	}  	return 0; } 

相关内容

热门资讯

玩家必看教程“福建大玩家万能辅... 玩家必看教程“福建大玩家万能辅助器”其实是有挂(辅助挂)详细辅助攻略教程辅助器中分为三种模型:软件透...
透视实锤!wepoker私人局... 透视实锤!wepoker私人局开挂视频,多乐小程序辅助工具,线上教程(有挂教程);1、该软件可以轻松...
一分钟揭秘“奇迹免费脚本辅助工... 一分钟揭秘“奇迹免费脚本辅助工具”pokerworld辅助器(最初存在有挂);小薇(透视辅助)致您一...
必备科技“闲来辅助器下载”果然... 必备科技“闲来辅助器下载”果然真的有挂(辅助挂)详细辅助揭秘教程1)辅助挂:进一步探索辅助透视大陆,...
透视科技!德扑圈透视,菠萝辅助... 透视科技!德扑圈透视,菠萝辅助器1.3,揭秘教程(有挂攻略);1、下载好菠萝辅助器1.3辅助软件之后...
一分钟带你了解“亿游十三道辅助... 一分钟带你了解“亿游十三道辅助”wepoker养号规律(本然是有挂);致您一封信;亲爱亿游十三道辅助...
一分钟揭秘“四川血战到底辅助”... 一分钟揭秘“四川血战到底辅助”总是是真的有挂(辅助挂)详细辅助必赢方法1、一分钟揭秘“四川血战到底辅...
透视存在!智星菠萝透视,开心泉... 透视存在!智星菠萝透视,开心泉州小程序有挂吗,力荐教程(有挂技巧)1、开心泉州小程序有挂吗透视辅助简...
带你了解“广东雀神祈福真的有用... 1、带你了解“广东雀神祈福真的有用吗”pokemomo辅助工具(本然是有挂);详细教程。2、广东雀神...
玩家科普“边锋干瞪眼ios辅助... 玩家科普“边锋干瞪眼ios辅助微信”总是是真的有挂(辅助挂)详细辅助玩家教你;边锋干瞪眼辅助器中分为...