【BZOJ4429】[Nwerc2015] Elementary Math小学数学 最大流

【BZOJ4429】[Nwerc2015] Elementary Math小学数学

Description

Ellen给她的学生教小学数学。期末考试已经来临了。考试有n个题目,每一个题目学生们都要对一对数字进行加(+),减(-),乘(*)运算。

Ellen已经选好了n对数。剩下的是决定学生们应该对每对数执行什么运算。为了不让学生们感到厌烦,Ellen想确保n个正确答案都不一样。

请帮助Ellen自动化地构建考试。

Input

输入包括:

第一行是一个整数n(1<=n<=2500),表示共有n道题目。

接下来n行每行有2个整数a和b(-10^6<=a,b<=10^6),表示每一题使用的整数。

Output

对于输入中的每一对(a,b),输出一行有效的方程。每一个方程应该包含5部分:a,+、-、*中的一个运算符,b,=,答案。N个答案必须不同。

如果有多个有效答案,你可以输出任意一个。如果没有答案,输出“impossible”。

Sample Input

Sample input 1
4
1 5
3 3
4 5
-1 -6
Sample input 2
4
-4 2
-4 2
-4 2
-4 2

Sample Output

Sample output 1
1 + 5 = 6
3 * 3 = 9
4 - 5 = -1
-1 - -6 = 5
Sample output 2
impossible

题解:傻题,将所有可能的结果用map存一下,然后建图跑最大流即可。

#include <cstdio>
#include <cstring>
#include <iostream>
#include <queue>
#include <map>
using namespace std;
typedef long long ll;
queue<int> q;
int n,m,cnt,S,T,ans;
ll ref[10010],ra[2510],rb[2510];
int to[100000],next[100000],head[10010],val[100000],d[10010];
map<ll,int> mp;

inline void add(int a,int b,int c)
{
	to[cnt]=b,val[cnt]=c,next[cnt]=head[a],head[a]=cnt++;
	to[cnt]=a,val[cnt]=0,next[cnt]=head[b],head[b]=cnt++;
}
int dfs(int x,int mf)
{
	if(x==T)	return mf;
	int i,k,temp=mf;
	for(i=head[x];i!=-1;i=next[i])	if(d[to[i]]==d[x]+1&&val[i])
	{
		k=dfs(to[i],min(temp,val[i]));
		if(!k)	d[to[i]]=0;
		temp-=k,val[i]-=k,val[i^1]+=k;
		if(!temp)	break;
	}
	return mf-temp;
}
int bfs()
{
	while(!q.empty())	q.pop();
	memset(d,0,sizeof(d));
	q.push(S),d[S]=1;
	int i,u;
	while(!q.empty())
	{
		u=q.front(),q.pop();
		for(i=head[u];i!=-1;i=next[i])	if(!d[to[i]]&&val[i])
		{
			d[to[i]]=d[u]+1;
			if(to[i]==T)	return 1;
			q.push(to[i]);
		}
	}
	return 0;
}
inline int rd()
{
	int ret=0,f=1;	char gc=getchar();
	while(gc<‘0‘||gc>‘9‘)	{if(gc==‘-‘)	f=-f;	gc=getchar();}
	while(gc>=‘0‘&&gc<=‘9‘)	ret=ret*10+(gc^‘0‘),gc=getchar();
	return ret*f;
}
int main()
{
	n=m=rd(),S=0;
	int i,j;
	memset(head,-1,sizeof(head));
	for(i=1;i<=n;i++)
	{
		ra[i]=rd(),rb[i]=rd();
		if(!mp[ra[i]+rb[i]])	mp[ra[i]+rb[i]]=++m,ref[m]=ra[i]+rb[i];
		if(!mp[ra[i]-rb[i]])	mp[ra[i]-rb[i]]=++m,ref[m]=ra[i]-rb[i];
		if(!mp[ra[i]*rb[i]])	mp[ra[i]*rb[i]]=++m,ref[m]=ra[i]*rb[i];
		add(i,mp[ra[i]+rb[i]],1);
		add(i,mp[ra[i]-rb[i]],1);
		add(i,mp[ra[i]*rb[i]],1);
		add(S,i,1);
	}
	T=m+1;
	for(i=n+1;i<=m;i++)	add(i,T,1);
	while(bfs())	ans+=dfs(S,1<<30);
	if(ans!=n)
	{
		printf("impossible");
		return 0;
	}
	for(i=1;i<=n;i++)
	{
		for(j=head[i];j!=-1;j=next[j])	if(!val[j])
		{
			if(ref[to[j]]==ra[i]+rb[i])	printf("%lld + %lld = %lld\n",ra[i],rb[i],ra[i]+rb[i]);
			else	if(ref[to[j]]==ra[i]-rb[i])	printf("%lld - %lld = %lld\n",ra[i],rb[i],ra[i]-rb[i]);
			else	if(ref[to[j]]==ra[i]*rb[i])	printf("%lld * %lld = %lld\n",ra[i],rb[i],ra[i]*rb[i]);
		}
	}
	return 0;
}
时间: 2024-10-12 22:59:43

【BZOJ4429】[Nwerc2015] Elementary Math小学数学 最大流的相关文章

[bzoj4429] [Nwerc2015] Elementary Math小学数学

一开始以为是2-sat..QAQ 膜了下题解..把各个答案离散化后,每对数与答案之间连边,看最大匹配数是否等于n 1 #include<cstdio> 2 #include<iostream> 3 #include<cstring> 4 #include<algorithm> 5 #define ll long long 6 using namespace std; 7 const int maxn=2523<<2; 8 struct zs1{l

JAVA之旅(二十三)——System,RunTime,Date,Calendar,Math的数学运算

JAVA之旅(二十三)--System,RunTime,Date,Calendar,Math的数学运算 map实在是太难写了,整理得我都晕都转向了,以后看来需要开一个专题来讲这个了,现在我们来时来学习一些新的小东西吧 一.System 翻译过来系统的意思,系统类,里面的方法都是静态的,可以直接调用 我们来演示一下吧,先从获取系统信息开始: package com.lgl.hellojava; import java.util.Properties; public class HelloJJAVA

PHP 的 BC MATH 系列数学函数

一.常见问题 用 PHP 做计算时经常会遇到精度带来的问题,下面来看两个常见的例子: 1. 运算比较 下面表达式输出的结果不是相等: <?php echo 2.01 - 0.01 == 2 ? '相等' : '不相等'; // 不相等 2. 类型转换 下面表达式输出的结果不是201(如果想输出你想要的结果,需要先转 string 再转 int): <?php $num = intval(2.01 * 100); var_dump($num); // int(200) 你也许会觉得很奇怪,然而这

Math concepts / 数学概念

链接网址:Math concepts / 数学概念 – https://www.codelast.com/math-concepts-%e6%95%b0%e5%ad%a6%e6%a6%82%e5%bf%b5/ 这里记录了我在学习过程中遇到或总结的一些基础数学概念,保存于此,与需要者共享. Following are some basic math concepts I read or summarized in my learning process, I wrote them down her

【小学数学论文】浅析小学学生数学计算能力的培养

浅析小学学生数学计算能力的培养 [导读] 本文是小学数学优秀论文范文2000字至3000字完整版<新课程标准>提出了关于"使学生能够正确地进行整数.小数.分数的四则计算,对其中一些基本的计算,要达到一定的熟练程度,并逐步做到计算方法合理.灵活"的教学要求. <新课程标准>提出了关于"使学生能够正确地进行整数.小数.分数的四则计算,对其中一些基本的计算,要达到一定的熟练程度,并逐步做到计算方法合理.灵活"的教学要求. 我对每次的测试卷进行分析,

java.util.Math类--数学相关的工具类

Math类--数学相关的工具类 java.util.Math类是数学相关的工具类,里面提供了大量的静态方法,完成与数学运算相关的操作. public static double abs(double num);获取绝对值.有多种重载: public static double ceil(double num);向上取整. public static double floor(double num);向下取整. public static long round(double num);四舍五入.

关于JS的知识,Math(数学对象)

2016年11月24日,星期四 一.理论知识: 1.一个等号=代表赋值: 2.运算顺序:从右向左: 3.数学运算符:+ - * % / ^ : 4.科学计数法:1000 = 1e3: 二.实验代码: 三.理论: 1.a++等于a =a+1: a++的顺序是先赋值,再计算. 代码: <script> var a = 10; var b = 1; //a = a+1; b =++a; document.write(a); </script> 2.字符串的连接符:+ <script

iOS math.h数学函数

在实际工作中有些程序不可避免的需要使用数学函数进行计算,比如地图程序的地理坐标到地图坐标的变换.Objective-C做为ANSI C的扩展,使用C标准库头文件<math.h>中定义的数学常量宏及数学函数来实现基本的数学计算操作,所以不必费神再在Cocoa Foundation中寻找相应的函数和类了.这里列出一些常用宏和数学函数,更详细的信息还是需要去查阅<math.h>头文件. 数学常量:#define M_E         2.718281828459045235360287

Math concepts / 数学概念(转)

https://www.codelast.com/math-concepts-%E6%95%B0%E5%AD%A6%E6%A6%82%E5%BF%B5/ 这里记录了我在学习过程中遇到或总结的一些基础数学概念,保存于此,与需要者共享. Following are some basic math concepts I read or summarized in my learning process, I wrote them down here to share with those who ne