【数学】XMU 1593 找数字
题目链接:
http://acm.xmu.edu.cn/JudgeOnline/problem.php?id=1593
题目大意:
T组数据,n个数,只有一种出现q次,其余的出现p次。(1<=T<=100,1<=n<=107,1<p,q<200,gcd(p,q)=1)
题目思路:
【数学】
我也不知道这题算不算数学类问题,总之我是不会做的。看了题解还是有些懵逼。
还是orz一下学长吧
我们想象一个简化版的:有n个数字,其中有1个数会出现1次,其余数都会出现两次,求出现1次的这个数是多少?
因为x^x=,所以对所有数取亦或^就行了。
这题也是同样的思路,我们希望达到这样一种状态:对出现p次的数进行操作后,会抵消为0,所以我们想到了p进制:举个例子p=,数字11出现了7次,(十进制)=(7进制),然后按位分离计算——对所有数转为p进制后,各个位分离计算。
(7进制)分离开,得到1和4,于是有4(7进制)*=,做无进位加法,就是0。
所以,一个数转为p进制后,按位分离开,然后做p次无进位加法,就是0。
上面就是核心思路。至于gcd(p,q)=1方便之后还原出答案。
其他自己想了。
学长的题解。
  f[i]表示数字i不进位加了q次完在p进制中为f[i],p和q互质所以f[i]和i一一对应(证明不会。。)
  只需要通过得到的答案中的数倒推回去就可以知道原来的数是几,之后还原回10进制答案
//
//by coolxxx
//
#include<iostream>
#include<algorithm>
#include<string>
#include<iomanip>
#include<memory.h>
#include<time.h>
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<stdbool.h>
#include<math.h>
#define min(a,b) ((a)<(b)?(a):(b))
#define max(a,b) ((a)>(b)?(a):(b))
#define abs(a) ((a)>0?(a):(-(a)))
#define lowbit(a) (a&(-a))
#define sqr(a) ((a)*(a))
#define swap(a,b) ((a)^=(b),(b)^=(a),(a)^=(b))
#define eps 1e-8
#define J 10
#define MAX 0x7f7f7f7f
#define PI 3.1415926535897
#define inf 10000000
#define N 104
using namespace std;
int n,m,lll,ans,cas;
int p,q;
int mi[N],a[N],f[N];
void work(int x)
{
int i,j;
for(i=m;i>= && x;i--)
{
if(x>=mi[i])
{
a[i]+=x/mi[i];
x%=mi[i];
a[i]%=p;
}
}
}
int main()
{
#ifndef ONLINE_JUDGE
// freopen("1.txt","r",stdin);
// freopen("2.txt","w",stdout);
#endif
int i,j,k,l;
// while(~scanf("%s",s1))
// while(~scanf("%d",&n))
for(scanf("%d",&cas),l=;l<=cas;l++)
{
memset(a,,sizeof(a));
scanf("%d%d%d",&n,&p,&q);
for(i=;i<p;i++)f[(i*q)%p]=i;
for(i=,mi[]=;mi[i-]<inf;i++)mi[i]=mi[i-]*p;
m=i-;
for(i=;i<=n;i++)
{
scanf("%d",&k);
work(k);
}
for(j=,i=;i<=m;i++)
j+=f[a[i]]*mi[i];
printf("Case %d:\n%d\n",l,j);
}
return ;
} /*
// //
*/
【数学】XMU 1593 找数字的更多相关文章
- java实现串中找数字
		串中找数字 以下的静态方法实现了:把串s中第一个出现的数字的值返回. 如果找不到数字,返回-1 例如: s = "abc24us43" 则返回2 s = "82445ad ... 
- 基于Visual C++2013拆解世界五百强面试题--题11-查找数字出现次数
		在排序数组中,找出给定数字出现的次数比如{ 1, 2, 2, 2, 3}中2的出现次数是3次 我们可使用二分查找发,分别查找出2最先出现的位置和最后出现的位置相减即可. 下面是上代码: #includ ... 
- Java--正则表达式-简单的在字符串中找数字
		import org.junit.Test; import java.util.regex.Matcher; import java.util.regex.Pattern; public class ... 
- April Fools Contest 2017 题解&源码(A,数学 B,数学 C,数学 D,字符串 E,数字逻辑 F,排序,卡时间,G,数学)
		A. Numbers Joke time limit per test:2 seconds memory limit per test:64 megabytes input:standard inpu ... 
- 课堂练习之找数字0-N中“1”出现的次数
		一.题目与要求 题目:给定一个十进制的正整数,写下从1开始,到N的所有整数,然后数一下其中出现“1”的个数. 要求:1.写一个函数 f(N) ,返回1 到 N 之间出现的“1”的个数.例如 f(12) ... 
- 科普:String hashCode 方法为什么选择数字31作为乘子
		1. 背景 某天,我在写代码的时候,无意中点开了 String hashCode 方法.然后大致看了一下 hashCode 的实现,发现并不是很复杂.但是我从源码中发现了一个奇怪的数字,也就是本文的主 ... 
- String hashCode 方法为什么选择数字31作为乘子
		1. 背景 某天,我在写代码的时候,无意中点开了 String hashCode 方法.然后大致看了一下 hashCode 的实现,发现并不是很复杂.但是我从源码中发现了一个奇怪的数字,也就是本文的主 ... 
- 【转】String hashCode 方法为什么选择数字31作为乘子
		某天,我在写代码的时候,无意中点开了 String hashCode 方法.然后大致看了一下 hashCode 的实现,发现并不是很复杂.但是我从源码中发现了一个奇怪的数字,也就是本文的主角31.这个 ... 
- String hashCode 这个数字,很多人不知道!
		作者:coolblog segmentfault.com/a/1190000010799123 1. 背景 某天,我在写代码的时候,无意中点开了 String hashCode 方法.然后大致看了一下 ... 
随机推荐
- 蓝牙(BLE)应用框架接口设计和应用开发——以TI CC2541为例
			本文从功能需求的角度分析一般蓝牙BLE单芯片的应用框架(SDK Framework)的接口设计过程,并以TI CC2541为例说明BLE的应用开发方法. 一.应用框架(Framework) 我们熟知的 ... 
- UNDERSTANDING VOLATILE VIA EXAMPLE--reference
			We have spent last couple of months stabilizing the lock detection functionality in Plumbr. During t ... 
- spring定时器任务多任务串行执行问题排查
			最近发现个生产问题,定时器任务某些任务没有及时执行.经过研究排查发现spring 定时器任务scheduled-tasks默认配置是单线程串行执行的,这就造成了若某个任务执行时间过长,其他任务一直在排 ... 
- 9.6noip模拟试题
			题目名称 盘子序列 四轮车 点名 提交文件 disk.pas/c/cpp car.pas/c/cpp rollcall.pas/c/cpp 输入文件 disk.in car.in rollcall.i ... 
- left ,right ,cross ,full/left outer join/区别 详解
			--创建测试表wwif OBJECT_ID('qq') is not null drop table qqcreate table qq([序号] varchar(5),[内容1] varchar(1 ... 
- JavaScript Unicode字符操作
			charCodeAt() 方法 定义和用法charCodeAt() 方法可返回指定位置的字符的 Unicode 编码.这个返回值是 0 - 65535 之间的整数.方法 charCodeAt() 与 ... 
- (转)PHP数组的总结(很全面啊)
			一.什么是数组数组就是一组数据的集合,把一系列数据组织起来,形成一个可操作的整体.数组的每个实体都包含两项:键和值. 二.声明数据在PHP中声明数组的方式主要有两种:一是应用array()函数声明数组 ... 
- ubuntu下安装Vmare Workstation,并安装mac补丁
			最近想学习一下关于ios方面的开发,但是苦于自己的电脑已经装了两个系统:一个win7,一个ubuntu.两系统均装在物理硬盘上,不想格盘,所以装个虚拟机玩玩.决定使用Vmare Workstation ... 
- 深入理解offsetTop与offsetLeft
			做为走上前端不归路的我,以前只是认为offsetTop是元素的左边框至包含元素offsetParent的左内边框之间的像素距离,同理offsetRight是相对于上内边框.那么问题来了,包含元素off ... 
- C++拾遗(三)关于复合类型
			数组相关 初始化只能在定义的时候使用,不能把数组赋给另一个数组. 初始化可以提供比元素数目少的初值,其它元素将被置为0. 字符char数组只有在以\0结尾时才是一个字符串.sizeof()返回数组的长 ... 
