acdream 1210 Chinese Girls' Amusement (打表找规律)
题意:有n个女孩围成一个圈从第1号女孩开始有一个球,可以往编号大的抛去(像传绣球一样绕着环来传),每次必须抛给左边第k个人,比如1号会抛给1+k号女孩。给出女孩的人数,如果他们都每个人都想要碰到球一次,那么这个k应该是多少(满足 1 ≤ K ≤ N/2 且 k必须尽量大)? 例如:n=7,那么1号开始拿球,抛球的顺序是 1, 4, 7, 3, 6, 2, 5, 1. 当球重新回到1女孩手中时,每个人刚好只玩了一次。注:这个数字相当大(3 ≤ N ≤ 102000)
思路:
方法(1):
暴力本地打表,发现n为奇数时,k=(n-1)/2即可。n为偶数时,规律如下图(左列是n,右列是k):

如果n为偶数,且n/2为偶数时,k=(n/2)-1。如果n为偶数,且n/2为奇数时,k=(n/2)-2。需要用到大数的除法和减法。
方法(2):如果能够经过若干次传球且未开始循环,将球抛到第n个女孩那里去,那么肯定可以全部人玩一次,比如1 2 3 4 5 6 7,应该k=3,第1次传给4号,第2次就到达7号,且还没开始循环。那么7号肯定可以传给3号,因为1号传给4号,7号自然就传给3号,接着球又到了6号那里。接续循环下去,球肯定会重回1号手中,且大家都只玩一次。
那么从n/2开始,逐个递减试,看能不能n模k为1。
// 求模 N%(N/2) != 0 即是结果!
// 奇数:(n-1)/2
// 偶数: n/2 - 1 #include <iostream>
#include <cstdio>
#include <string> using namespace std; // 减一操作 strNum 正序存储 如 100000
void subOne(string &strNum)
{
if (strNum[strNum.length()-] > '')
{
strNum[strNum.length()-]--;
return;
} // 可能需要逐位减一
for(int i=strNum.length()-; i>=; --i)
{
if (strNum[i] == '')
{
strNum[i] = '';
}
else
{
strNum[i]--;
break;
}
} if (strNum[] == '')
strNum.erase(, ); // 移除头位的0
} // strNum / 2
void divHalf(string &strNum)
{
int s = ;
string num;
for(int i=; i<strNum.length(); ++i)
{
s = s* + (strNum[i]-'');
num += (s/ + '');
s %= ;
} // 去掉前导0
int i = ;
for(i=; i<num.length(); ++i)
{
if (num[i] != '')
break;
}
strNum = num.substr(i);
} int main(void)
{
//freopen("in.txt", "r", stdin); string strNum;
while(cin>>strNum)
{
// 末位数字判断奇偶性
int k = strNum[strNum.length()-]-'';
if (k%==)
{
// 偶数: n/2 - 1
divHalf(strNum);
subOne(strNum); // 这里需要特殊处理
while()
{
k = strNum[strNum.length()-]-'';
if (k% != )
break; subOne(strNum);
}
}
else
{
// 奇数:(n-1)/2
subOne(strNum);
divHalf(strNum);
}
cout<<strNum<<endl;
} return ;
}
别人的AC代码
#include <bits/stdc++.h>
#define LL long long
using namespace std;
const int N=;
int a, b;
int has[N];
char s[N];
char ans[N]; void div(char * src,int n,char *dest)
{
int len = strlen(src),i,k,t=,s=;
bool flag = true; //商是否有了第一个有效位,防止商首部一直出现0
for(i=,k=; i<len; i++)
{
t = s*+(src[i]-); //新余数
if(t/n> || t==) //余数为0要修改商
{
dest[k++] = t/n+,s = t%n,flag = false;
}
else //不够除,修改余数
{
s = t;
if(!flag) //商已经有有效位了,补零
dest[k++] = '';
}
}
dest[k]='\0';
} bool comp(string num1,string num2)
{
int leng=num1.length(),i;
for(i=;i<leng;i++){if(num1[i]!='')break;}
num1=num1.substr(i,leng);
if(num1.length()==)num1=""; leng=num2.length();
for(i=;i<leng;i++){if(num2[i]!='')break;}
num2=num2.substr(i,leng);
if(num2.length()==)num2=""; if(num1.length()>num2.length())return true;
else if(num1.length()==num2.length())
{
if(num1>=num2)return true;
else return false;
}
else return false;
}
void _minus(string num1,string num2,string &result)
{ if(comp(num2,num1)){string ss=num1;num1=num2;num2=ss;}
reverse(num1.begin(),num1.end());
reverse(num2.begin(),num2.end()); result=""; int i;
for(i=;i<int(num1.length())&&i<int(num2.length());i++)
{
char c=num1[i]-num2[i]+;
result=result+c;
}
if(i<int(num1.length()))
for(;i<int(num1.length());i++)
result=result+num1[i]; int jiewei=;
for(i=;i<int(result.length());i++)
{
int zhi=result[i]-+jiewei;
if(zhi<) {zhi=zhi+;jiewei=-;}
else jiewei=;
result[i]=(char)(zhi+);
} for(i=result.length()-;i>=;i--)
if(result[i]!='')
break; result=result.substr(,i+);
reverse(result.begin(),result.end());
if(result.length()==)result="";
}
//****上面不用看了,大数模版 int main()
{
//freopen("input.txt", "r", stdin); while(gets(s))
{
int len=strlen(s);
if(((s[len-]-'')&)==) //奇数
{
div(s,,ans);
puts(ans);
}
else
{
div(s,,ans); //先减半
len=strlen(ans);
if(((ans[len-]-'')&)== ) //减半后为偶数
{
string tmp(ans);
string res="";
_minus(tmp,"",res);//减1
cout<<res<<endl;
}
else//减半后为奇数
{
string tmp(ans);
string res="";
_minus(tmp,"",res);//减2
cout<<res<<endl;
}
}
}
return ;
}
AC代码

acdream 1210 Chinese Girls' Amusement (打表找规律)的更多相关文章
- ACdream 1210	Chinese Girls' Amusement(高精度)
		Chinese Girls' Amusement Time Limit:1000MS Memory Limit:64000KB 64bit IO Format:%lld & ... 
- ACDream:1210:Chinese Girls' Amusement【水题】
		Chinese Girls' Amusement Time Limit: 2000/1000MS (Java/Others)Memory Limit: 128000/64000KB (Java/Oth ... 
- Acdream  Chinese Girls' Amusement
		A - Chinese Girls' Amusement Time Limit: 2000/1000MS (Java/Others) Memory Limit: 128000/64000KB (Jav ... 
- 数学+高精度 ZOJ 2313 Chinese Girls' Amusement
		题目传送门 /* 杭电一题(ACM_steps 2.2.4)的升级版,使用到高精度: 这次不是简单的猜出来的了,求的是GCD (n, k) == 1 最大的k(1, n/2): 1. 若n是奇数,则k ... 
- hdu 3032 Nim or not Nim? (SG函数博弈+打表找规律)
		Nim or not Nim? Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Sub ... 
- HDU 5753  Permutation Bo (推导 or 打表找规律)
		Permutation Bo 题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=5753 Description There are two sequen ... 
- HDU 4861  Couple doubi (数论 or 打表找规律)
		Couple doubi 题目链接: http://acm.hust.edu.cn/vjudge/contest/121334#problem/D Description DouBiXp has a ... 
- HDU2149-Good Luck in CET-4 Everybody!(博弈,打表找规律)
		Good Luck in CET-4 Everybody! Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K ... 
- 【ZOJ】3785 What day is that day?  ——浅谈KMP在ACM竞赛中的暴力打表找规律中的应用
		转载请声明出处:http://www.cnblogs.com/kevince/p/3887827.html ——By Kevince 首先声明一下,这里的规律指的是循环,即找到最小循环周期. 这 ... 
随机推荐
- STS中取消show in Breadcrumb方法
			前言:STS是Spring产品下的一个开发工具,它和eclipse很像,只不过对Spring有更好的兼容.Show in Breadcrumb是快速导航条,可以清晰的看到我们当前的类,属性或方法的导航 ... 
- POJ 2528 Mayor's posters (线段树,染色问题,离散化要注意)
			做这题建议看一下该题的discuss. #include <iostream> #include <stdio.h> #include <string.h> #in ... 
- HDU 1385 Minimum Transport Cost (最短路,并输出路径)
			题意:给你n个城市,一些城市之间会有一些道路,有边权.并且每个城市都会有一些费用. 然后你一些起点和终点,问你从起点到终点最少需要多少路途. 除了起点和终点,最短路的图中的每个城市的费用都要加上. 思 ... 
- JavaScript 隐式转换
			javascript 中的怪癖,js运算符隐式类型转换 x + "" //等价于 String(x) + x //等价于 Number(x),也可以写成x-0 !!x //等价于 ... 
- hdu 4704 Sum
			思路:对于给定的n,s(i)即将n分解为i个数的组合数,也就是在n-1个位置插入i-1个板即C(n-1,i-1); ∑S=2^(n-1); phi(1000000007)=1000000006; 对于 ... 
- 【转载】Eclipse自动编译问题
			今天调试的时候发现问题:调试的时候竟然在我注释的里面走,当时那个郁闷啊,每次都要clean下才可以,晚上感觉不对劲,上网查了查,原来是bulid automatically这个我把勾去掉了,下面是原文 ... 
- http://www.mxchip.com/talk/news/jishuwenzhang/2014-09-11/67.html
			http://www.mxchip.com/talk/news/jishuwenzhang/2014-09-11/67.html 
- iOS动画篇:UIView动画
			iOS的动画效果一直都很棒很,给人的感觉就是很炫酷很流畅,起到增强用户体验的作用.在APP开发中实现动画效果有很多种方式,对于简单的应用场景,我们可以使用UIKit提供的动画来实现. UIView动画 ... 
- python url编码,解码
			>>> urllib.unquote('%E4%B8%BD%E6%B1%9F') >>> data '\xe4\xb8\xbd\xe6\xb1\x9f' >& ... 
- Java Project和Web Project 区别
			java project是java工程,不包括JSP等前台页面的代码 大部分是CS结构的工程和一些jar包 web project是web工程,是BS结构的系统 web project部署到服务器上 ... 
