博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[杂题]CSUOJ1274Balls and Boxes
阅读量:4684 次
发布时间:2019-06-09

本文共 2247 字,大约阅读时间需要 7 分钟。

题意:中文题 题意不多赘述

值得注意的是n<m 不必考虑n==m的情况 (m是盒子个数, n是每次选取的盒子个数, 不要弄反了!)

 

这题一看就是同余方程

 

每次选取n个盒子放球 也就是说每次都增加n个球

最后m个盒子中球的个数相等, 也就是最终状态球的总数为m的倍数

于是 很容易能得到同余方程:sum+x*n=y*m   (sum为出示状态共有sum个球)

其中x为 需要选x次盒子放球  

  y为 最终每个盒子有y个球

 

接下来只要解同余方程

若无解, 则无论怎样操作都不能达到这个目的

若有解 还需满足几个条件:

  (首先需要记录一下:初始状态最多的盒子里有maxn个球, 最少的有minn个球)

  y>=maxn   也就是最后每个盒子里的球的个数 肯定要大于或者等于初始状态的 盒子中有的球的最大个数

  x>=y-minn  也就是 选盒子放球的次数 肯定要大于或者等于 最终状态每个盒子内球的个数 与 初始状态盒子中有的球的最小个数 之差

 

1 #include 
2 #include
3 #include
4 #include
5 #include
6 #include
7 #include
8 #include
9 #include
10 #include
11 #include
12 using namespace std;13 #include
14 #include
15 #include
16 #include
17 #include
18 #include
19 typedef long long LL;20 typedef long double LD;21 const double pi=acos(-1.0);22 const double eps=1e-9;23 #define INF 0x3f3f3f24 #define lson l, m, rt<<125 #define rson m+1, r, rt<<1|126 typedef pair
PI;27 typedef pair
PP;28 #ifdef _WIN3229 #define LLD "%I64d"30 #else31 #define LLD "%lld"32 #endif33 //#pragma comment(linker, "/STACK:1024000000,1024000000")34 //LL quick(LL a, LL b){LL ans=1;while(b){if(b & 1)ans*=a;a=a*a;b>>=1;}return ans;}35 //inline int read(){char ch=' ';int ans=0;while(ch<'0' || ch>'9')ch=getchar();while(ch<='9' && ch>='0'){ans=ans*10+ch-'0';ch=getchar();}return ans;}36 inline void print(LL x){printf(LLD, x);puts("");}37 //inline void read(LL &ret){char c;int sgn;LL bit=0.1;if(c=getchar(),c==EOF) return ;while(c!='-'&&c!='.'&&(c<'0'||c>'9')) c=getchar();sgn=(c=='-')?-1:1;ret=(c=='-')?0:(c-'0');while(c=getchar(),c>='0'&&c<='9') ret=ret*10+(c-'0');if(c==' '||c=='\n'){ ret*=sgn; return ; }while(c=getchar(),c>='0'&&c<='9') ret+=(c-'0')*bit,bit/=10;ret*=sgn;}38 39 void ex_gcd(LL a, LL b, LL &d, LL &x, LL &y)40 {41 if(b)42 {43 ex_gcd(b, a%b, d, x, y);44 LL tmp=x;45 x=y;46 y=tmp-(a/b)*y;47 }48 else49 {50 x=1, y=0, d=a;51 return ;52 }53 }54 int main()55 {56 int t;57 scanf("%d", &t);58 while(t--)59 {60 int n, m;61 scanf("%d%d", &n, &m);62 int sum=0, maxn=0, minn=INT_MAX;63 for(int i=0;i
CSUOJ 1274

 

 

 

最后。。。以上是纯YY的结果。。。具体的证明还是直接看官方题解好了,反正我也证不出来(题解:http://acm.csu.edu.cn/csuacm/2013/04/)

 

转载于:https://www.cnblogs.com/Empress/p/4156296.html

你可能感兴趣的文章
23 Java学习之RandomAccessFile
查看>>
P2709 小B的询问
查看>>
润乾报表 动态控制文本的显示
查看>>
[oracle] 如何使用myBatis在数据库中插入数据并返回主键
查看>>
PHP echo 和 print 语句
查看>>
第一讲 一个简单的Qt程序分析
查看>>
Centos 6.5下的OPENJDK卸载和SUN的JDK安装、环境变量配置
查看>>
poj 1979 Red and Black(dfs)
查看>>
【.Net基础03】HttpWebRequest模拟浏览器登陆
查看>>
UML-画类图与交互图的顺序
查看>>
6月7 考试系统
查看>>
mysql 基本操作
查看>>
zTree async 动态参数处理
查看>>
Oracle学习之常见错误整理
查看>>
HTC Sensation G14开盒
查看>>
lock_sga引起的ksvcreate :process(m000) creation failed
查看>>
数据库插入数据乱码问题
查看>>
OVER(PARTITION BY)函数用法
查看>>
altium annotate 选项设置 complete existing packages
查看>>
【模式识别与机器学习】——SVM举例
查看>>