2018CCPC网络赛 C - Dream

题意

给定一个P,现在可以以任意方式重载'+'和'*'两个符号,使得满足下列等式

其中定义如下

需要注意的是,重载过后的'*'需要满足以下要求:

也就是说,重载'*'之后通过计算得到的**(k=1,2,3,...,p-1)的取值对于集合{1,2,3,...,p-1}是一个一一映射的关系**

​​​​最后输出2*p行,按照自己重载的'+'和'*',输出:

思路

由于可以以任意方式重载,所以可以把a+b直接重载为a+0 ,此时等式变成了,,可以发现等式恒成立,现在只需要满足一一映射就可以了,可以想到把a*b直接重载为a+1 ,按照上面的定义,=>(也就是)=>(也就是)=>.....=>k+1

此时得到的集合就是{2,3,4,....,p}恰好与一一映射需要的集合差一个p 于是对a*b的重载中加一个判断如果得到p就返回1就可以解决这个问题

代码

cpp 复制代码
#include <map>
#include <set>
#include <queue>
#include <deque>
#include <cmath>
#include <vector>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <unordered_map>
using namespace std;
#define fi first
#define se second
#define pb push_back
#define pp pop_back()
#define int long long
#define laile cout<<"laile"<<endl
#define lowbit(x) ((x)&(-x))
#define double long double
#define sf(x) scanf("%lld",&x)
#define sff(x,y) scanf("%lld %lld",&x,&y)
#define sd(x) scanf("%Lf",&x)
#define sdd(x,y) scanf("%Lf %Lf",&x,&y)
#define _for(i,n) for(int i=0;i<(n);++i)
#define _rep(i,a,b) for(int i=(a);i<=(b);++i)
#define _pre(i,a,b) for(int i=(a);i>=(b);--i)
#define all(x) (x).begin(), (x).end()
#define IOS ios::sync_with_stdio(false);cin.tie(0);cout.tie(0)
int p;
int deal(int a,int b)
{
	int now=a+1;
	if(now==p)return 1;
	else return now;
}
void solve()
{
	cin>>p;
	_rep(i,1,p)
	{
		_rep(j,1,p)
			cout<<(i-1)<<" ";
		cout<<'\n';
	}
	_rep(i,1,p)
	{
		_rep(j,1,p)
		cout<<deal(i-1,j-1)<<" ";
		cout<<'\n';
	}
	return ;
}
signed main()
{
	IOS;
	int T=1;
	cin>>T;
	while(T--)
		solve();
	return 0;
}
相关推荐
ZHOUPUYU几秒前
PHP性能分析与调优:从定位瓶颈到实战优化
开发语言·后端·html·php
yunyun321231 分钟前
C++与量子计算模拟
开发语言·c++·算法
CDN3602 分钟前
各种网站高防服务器选型:360CDN 高防够用吗?
服务器·网络·安全
嵌入式-老费3 分钟前
vivado hls的应用(带ddr读取的ip)
服务器·网络·tcp/ip
软件工程小施同学3 分钟前
区块链论文速读 CCF A--CCS 2025 (2) 附pdf下载
网络·pdf·区块链
weixin_462901973 分钟前
ESP32电压显示
开发语言·javascript·css·python
探序基因8 分钟前
R语言读取单细胞转录组基因表达矩阵loom文件
开发语言·r语言
大尚来也9 分钟前
高并发架构下的缓存“三座大山”:穿透、雪崩与击穿的深度突围
开发语言
暮冬-  Gentle°9 分钟前
移动设备上的C++优化
开发语言·c++·算法
2401_8747325311 分钟前
C++中的装饰器模式高级应用
开发语言·c++·算法