我想说这是一道签到题,意思就是本次测试中最水的一道,不过我这样说你真的愿意相信我吗?哈哈,题目是这样的给你一下小数,然后请告诉我分别告诉我这个小数的循环节的循环次数、循环节以及循环节长度
标签:
我想说这是一道签到题,意思就是本次测试中最水的一道,不过我这样说你真的愿意相信我吗?哈哈,题目是这样的给你一下小数,然后请告诉我分别告诉我这个小数的循环节的循环次数、循环节以及循环节长度
输入包括多组测试数据每组测试数据1行,包括一个小数,小数的长度不超过200,小数大于0小于100
分别输出这个小数的循环节的长度、循环节以及循环次数,中间以一个空格间隔
#include<stdio.h>
#include<string.h>
char str[300];
char s[300];
int next[300];
int len;
void Get_Next()
{
int i=0,j=-1;
next[0]=-1;
while(i<len)
{
if(j==-1 || s[i]==s[j])
{
++i,++j;
next[i]=j;
}
else
j=next[j];
}
}
int main()
{
int i,T;
scanf("%d",&T);
while(T--)
{
scanf("%s",str);
len=strlen(str);
for(i=0;i<len;++i)
{
if(str[i]=='.')
break;
}
int k=0;
for(i=i+1;i<len;++i)
s[k++]=str[i];
len=k;
Get_Next();
printf("%d ",len-next[len]);//最大字符串长度
for(i=0;i<len-next[len];++i)
printf("%c",s[i]);
printf(" ");
printf("%d\n",len/(len-next[len]));//重复几次
}
return 0;
}
贪心的MZY去一个迷宫寻宝。已知:若MZY在位置(x, y),他下一次只能移动到(x-1, y)、(x+1, y)、(x, y-1)、(x, y+1)四个位置中的任一个(前提不能越界)。
毕竟他不是我,我可以直接飞到宝物那里去。由于MZY比较笨拙,他移动一步需要1分钟。请你帮他算出找到宝物所需要花费的最少时间。
迷宫是一个N*M的地图,图中只有四个数字。
0:此处是空的,可以走
1:此处有障碍,不可以走
2:MZY起点
3:宝物位置(只有一个宝物)
题目保证CZY至少有一条路可以到达宝物位置。
输入数据有多组。
每组以两个整数N和M开始,分别表示迷宫的行数和列数,接下来N行每行有M个数。(1 <= N, M <= 10)
输出MZY找到宝物的最少需要花费的时间。(以秒为单位)
#include<cstdio>
#include<queue>
using namespace std;
struct walk
{
int x,y;
int time;
friend bool operator < (walk a,walk b)
{
return a.time>b.time;
}
};
int n,m;
int map[20][20];
int sx,sy,ex,ey;
int dx[4]={1,0,0,-1};
int dy[4]={0,1,-1,0};
int min_time;
bool judge(int x,int y)
{
if(x>n ||x<1||y>m||y<1||map[x][y]==1) return 0;
return 1;
}
void BFS()
{
walk pos,next;
priority_queue<walk>q;
pos.x=sx;
pos.y=sy;
pos.time=0;
map[sx][sy]=1;
q.push(pos);
while(!q.empty())
{
pos=q.top();
q.pop();
for(int i=0;i<4;++i)
{
next.x=pos.x+dx[i];
next.y=pos.y+dy[i];
next.time=pos.time+1;
if(judge(next.x,next.y))
{
if(next.x==ex&&next.y==ey)
{
min_time=next.time;
}
map[next.x][next.y]=1;
q.push(next);
}
}
}
}
int main()
{
int i,j;
while(~scanf("%d%d",&n,&m))
{
for(i=1;i<=n;++i)
{
for(j=1;j<=m;++j)
{
scanf("%d",map[i]+j);
if(map[i][j]==2)
{
sx=i,sy=j;
}
if(map[i][j]==3)
{
ex=i,ey=j;
}
}
}
BFS();
printf("%d\n",min_time*60);
}
return 0;
}czy最近对组合数产生了浓厚的兴趣,一天他心血来潮,想排n个数字,但是很快他发现种类太多了,于是他决定从中随机找出m个数排,但还是太多了,所以他想请聪明的你写个程序帮助他找到所有种类的排列
输入包括多组测试数据,每组包括一行整数n(1<=n<10),m(1<=m<=n),空格间隔
按特定顺序输出所有组合。
特定顺序:每一个组合中的值从大到小排列,组合之间按逆字典序排列。
#include<stdio.h>
#include<string.h>
#define INF 0xfffffff
int a[20];
bool vis[20];
int m,n;
void DFS(int cnt)
{
if(cnt==n+1)
{
for(int i=1;i<=n;++i)
{
printf("%d",a[i]);
}
printf("\n");
return ;
}
for(int i=m;i>=1;--i)
{
a[cnt]=i;
if(vis[i]==0&&a[cnt]<a[cnt-1])
{
vis[i]=1;
DFS(cnt+1);
vis[i]=0;
}
}
}
int main()
{
while(~scanf("%d%d",&m,&n))
{
a[0]=INF;
memset(vis,0,sizeof(vis));
DFS(1);
}
return 0;
}
CZY遇到了一个萌妹子,他使出浑身解数想要博得她的好感,但是妹子居然是个数学学霸!一天,那个女孩在解数列问题时遇到了一点麻烦,她有数列的前3项,数列不是等比数列就是等差数列,她很想知道这个数列的第n项是什么,但是n可能很大,她算不出来,CZY很想帮她,可是CZY是个学渣,于是想请聪明的你来帮忙求出数列的第n项,由于数据可能太大了,最后的结果对200907取余就好
输入包含多组测试数据,每组测试数据包含4个整数,前三个整数是数列的前三项,最后一个数是n,四个数的范围都是1~10^9
输出这个数列的第n项%200907
#include<stdio.h>
#include<math.h>
#define LL long long
#define mod 200907
int res;
LL quick(int a,int b)//快速幂
{
int ans=res;
while(b!=0)
{
if(b&1) ans=(ans%mod*a)%mod;
a=(a%mod*a)%mod;
b>>=1; //b/=2;
}
return ans;
}
int main()
{
int n,i;
int t1,t2,t3;
long long res;
while(~scanf("%d %d %d %d",&t1,&t2,&t3,&n))
{
if(t2-t1==t3-t2)
{
res=(t1%200907+(n-1)*(t2-t1))%200907; //同模定理
}
else
{
int q=t2/t1;
res=t1;
quick(q,n-1);
for(i=1;i<n;++i)
{
res*=q;
if(res>200907) res%=200907;
}
}
printf("%lld\n",res);
}
return 0;
}
话说CZY来到了HPU之后,每天对着电脑码代码,码了一学期了,陈公公有一天敲代码敲累了,此刻的陈公公是身心疲惫啊,他突然想:要是有一个Girlfriend多好?于是,陈公公想要在学校找一个Girlfriend。话说在男女比7:1的比例之下很难找到意中人,是不是?可惜这难不倒我们“英(jing)姿(li)飒(feng)爽(fu)”的陈公公,找女友要先买礼物对吧。对于陈公公这种“壕”,当然要买高端大气上档次的啦!陈公公要斥巨资买条钻石手链,送给他心仪已久的女生(从此,陈公公又多了个外号“钻石陈”)。我们都知道手链五颜六色的很吸引人。陈公公也知道女生喜欢颜色比较多的手链,但是手链又不能毫无规律的颜色多而已。我们要买的手链必须是颜色够多,还要有规律,什么叫做有规律?就是有循环的。假如给定参照手链“RGB”,再给一个手链比如“RGBRGBRGB”它包含了3个参照手链。陈公公称包含值为:美丽度。因为包含3个参考串,所以这个手链美丽度就为3.


陈公公想要买一个美丽度大于1的手链,但是又不能只有一种颜色,怎么挑一个最好的呢?这个问题有点难想,并且可惜陈公公对颜色的分辨能力不够高(轻微色盲),不能很好的判断买哪一条手链,要不是陈公公自己都能编程解决这个问题了。陈公公很无奈啊,他想到了有爱心的协会成员,希望求助协会成员,请你帮他选一个最美的手链。这关乎到陈公公能否追到心意的女孩啊!人生大事啊!陈公公说了,能帮他解决这个问题的童鞋,他就会请你吃饭!PS:帮陈公公解决这个问题的人,记得找陈公公请客。
有多组测试数据,输入先给出参考手链(参考手链长度大于1),然后输入一个T(0<T<20),代表陈公公选的T组数据。每组数据第一行是参照手链,第二行是陈公公想知道美丽度的手链(长度不小于参考手链)。由于陈公公比较壕,所以他选的手链的珠子最多可以达到100000。
输出数据也有T行,每行输出,最大美丽度,和相应的手链。如果美丽度相同就输出手链最长的,看下面测试样例。
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
char substr[100010];
int next[100010];
int len;
char *q;
int max;
int len1,len2;
struct value
{
char str[100010];
int num;
int len;
}arr[30];
bool cmp(value a,value b)
{
if(a.num==b.num) return a.len>b.len;
return a.num>b.num;
}
void Get_Next()
{
int i=0,j=-1;
next[0]=-1;
while(i<len1)
{
if(j==-1 || substr[i]==substr[j])
{
++i,++j;
next[i]=j;
}
else
j=next[j];
}
}
int KMP(int t)
{
int i=0,j=0;
int cnt=0;
while(i<len2)
{
if(j==-1 || arr[t].str[i]==substr[j])
{
++i,++j;
if(j==len1)
{
cnt++;
j=0;
}
}
else
j=next[j];
}
return cnt;
}
int main()
{
int n;
while(~scanf("%s",substr))
{
len1=strlen(substr);
Get_Next();
scanf("%d",&n);
for(int i=0;i<n;++i)
{
scanf("%s",arr[i].str);
len2=strlen(arr[i].str);
arr[i].len=len2;
arr[i].num=KMP(i);
}
sort(arr,arr+n,cmp);
printf("%d %s\n",arr[0].num,arr[0].str);
}
return 0;
}
CZY终于又和萌妹子的关系又进了一步,终于知道了妹子的名字,原来她叫YY,CZY跟着那个女孩也学到了很多的数学知识,CZY感觉自己快要超神了,于是嘚瑟起来,YY对此不屑一顾,冷笑一声“呵呵”后,便给CZY出了一道数学题,YY给了CZY一个数n,又给了m个数,让他从中找一些数,让这些数的和等于n,并让他把所有的情况写出来。这下可把CZY给打击到了,于是他又来请教聪明的你,请你帮帮他
题目包含多组测试数据,每组测试数据包含两行,第一行包含两个整数n,m(1<=n,m<1000)
第二行包含m个数
按从大到小的顺序输出所有符合的情况,没有符合的情况就输出NONE
可怜的公主又被魔王抓走了。魔王这次准备在T时刻与公主成亲,不过公主深信智勇的骑士CZY肯定能将她救出。
已知:公主被关在一个两层的迷宫里,迷宫的入口是S(0,0,0),公主的位置用P表示,时空传输机用#表示,墙用*表示,平地用.表示。
CZY一进入时空传输机就会被转到另一层的相对位置,但如果被转到的位置是墙的话,那CZY就会被撞死。
CZY在一层中只能前后左右移动,每移动一格花1时刻。层间的移动只能通过时空传输机,且不需要任何时间。
输入有多组测试数据。
每个测试数据的前一行有三个整数N,M,T。 N,M迷宫的大小N*M(1 <= N,M <=10)。T如上所意。
接下去的前N*M表示迷宫的第一层的布置情况,后N*M表示迷宫第二层的布置情况。
如果CZY能够在T时刻能找到公主就输出“YES”,否则输出“NO”。
CZY总是遇到这样或那样的问题,现在他又遇到了一个,CZY接到一个大的工程,想想这是走上人生巅峰的第一步啊,CZY想想就高兴,可是这个工程太大了,他需要很多人的帮助才可以,但是为了方便工作,CZY希望他的团队两人两人之间都是朋友关系,或者间接是朋友关系。毕竟是大油水的工程啊,来了一群小伙伴报名,CYZ想请聪明的你帮忙算一算,他可以招到的最大的人数是多少
输入包含多组测试数据,每组测试数据第一行一个n,表示来报名的小伙伴们的编号1-100,后边接n行,每行两个整数a b,表示编号a和b的小伙伴是朋友关系
输出包括一行,即CZY可以招到的最大的人数是多少
#include<stdio.h>
int per[201];
int peo[201];
void init()
{
for(int i=1;i<=100;++i)
{
per[i]=i;
}
for(int i=1;i<=100;++i)
peo[i]=1;
}
int find(int x)
{
int r=x;
while(r!=per[r])
{
r=per[r];
}
per[x]=r;
return r;
}
void join(int x,int y)
{
int fx=find(x);
int fy=find(y);
if(fx!=fy)
{
per[fx]=fy;
peo[fy]+=peo[fx];
}
}
int main()
{
int n;
int a,b;
while(~scanf("%d",&n))
{
init();
while(n--)
{
scanf("%d%d",&a,&b);
join(a,b);
}
int max=-100;
for(int i=1;i<=100;++i)
{
if(per[i]==i)
{
if(max<peo[i]) max=peo[i];
}
}
printf("%d\n",max);
}
return 0;
}
YY喜欢读书,而且总是喜欢从书上摘取好的句子或词语,但是抄完之后她变忘了在哪,于是她就请CZY帮她,CZY感觉这我多我可咋找啊!
于是又来麻烦聪明的你,为了方便CZY早已用高端译码机器把句子变成的数字,他想让你告诉他句子在文章中出现的位置。(位置从1开始)
输入包括多组测试数据,每组测试数据包含三行,第一行包含两个整数n(1<=n<=1000000),m(1<=m<=1000),分别代表文章的长度,和所摘取的句子的长度,
第二行包含n个整数表示文章,第三行包括m各整数表示句子
输出所摘取的句子在文章中的位置
#include<stdio.h>
int arr[110],subarr[110];
int next[110];
int i,j;
int m,n;
int KMP()
{
i=1;j=1;
while(i<=m)
{
if(arr[i]==subarr[j])
{
++i,++j;
if(j==n+1)
{
return i-n;
}
}
else
{
j=1;
i=i-j+2;
}
}
}
int main()
{
while(~scanf("%d%d",&m,&n))
{
for(i=1;i<=m;++i)
scanf("%d",arr+i);
for(i=1;i<=n;++i)
scanf("%d",subarr+i);
printf("%d\n",KMP());
}
return 0;
}
//5 2
//1 2 3 4 5
//2 3
版权声明:本文为博主原创文章,未经博主允许不得转载。
标签:
原文地址:http://blog.csdn.net/yuzhiwei1995/article/details/47359815