poj3270 && poj 1026(置换问题)
| 1 2 3 4 5 6 |
| 3 6 5 1 4 2 |
思路:(参考北大的群论以及ACM_cxiove)
poj 3270
所以先计算出所有数的和sum,然后再在这个基础上选择是和 循环中最小的元素or所有数中最小的元素 交换。
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <cmath>
#define N 10100
typedef long long ll;
using namespace std;
int a[N];
int p[N];
int flag[N];
int tot;
struct node
{
int val;
int cnt;
} q[N];
int n;
void dfs(int u)
{
for(int i = 1; i <=n ; i++)
{
if(a[i] == u && !flag[i])
{
flag[i] = 1;
q[tot].val = min(q[tot].val,a[i]);
q[tot].cnt++;
dfs(p[i]);
}
}
} int main()
{
while(scanf("%d",&n)!=EOF)
{
int minx = 0x3f3f3f3f;
memset(flag,0,sizeof(flag));
int sum = 0;
for(int i = 1; i <= n; i++)
{
scanf("%d",&a[i]);
p[i] = a[i];
sum += a[i];
minx = min(minx,a[i]);
}
sort(p+1,p+1+n);
tot= 0; for(int i = 1; i <= n; i++)
{
if(flag[i]) continue;
q[tot].val = a[i];
q[tot].cnt = 1;
flag[i] = 1;
dfs(p[i]);
tot++;
} for(int i = 0; i < tot; i++)
{
sum += min(q[i].val*(q[i].cnt-2),minx*(q[i].cnt+1)+q[i].val);
}
printf("%d\n",sum);
}
return 0;
}
题意:
对于一个长度为n的字符串,有一个数组表示第i个字符放到那个位置。
输入多个字符串,问这样操作k次后的字符串是什么样子
找出循环的最小周期,求余计算
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <vector>
#include <cmath>
#define N 205
typedef long long ll;
using namespace std;
int a[N],p[N];
char ans[N],str[N];
int k,n; int fin(int i,int k) //肯能会产生循环,寻找最小周期;并且找出第i个字符会落在的某位
{
int j,t=i+1;
i++;
for(j=1; j<=k; j++)
{
i=a[i];
if(i==t)
{
for(i=t,t=0; t<(k%j); t++) //利用最小周期
i=a[i];
return i;
}
}
return i;
} int main()
{
while(scanf("%d",&n)!=EOF && n)
{
for(int i = 1; i <= n; i++)
scanf("%d",&a[i]); while(scanf("%d",&k) && k)
{
getchar();
gets(ans);
int L = strlen(ans);
if(L < n)
for(int i = L; i < n; i++)
ans[i] = ' ';
for(int i = 0; i < n; i++)
{
//printf("%d ",fin(i,k) - 1);
str[fin(i,k) - 1] = ans[i];
}
for(int i=n-1;; i--)
if(str[i]!=' ')
{
str[i+1]='\0';
break;
}
printf("%s\n",str);
}
printf("\n");
}
return 0;
}
poj3270 && poj 1026(置换问题)的更多相关文章
- poj 3270 置换
poj 置换的应用 黑书原题P248 /** 题意: 给定序列, 将其按升序排列, 每次交换的代价是两个数之和, 问代价最小是多少 思路:1.对于同一个循环节之内的,肯定是最小的与别的交换代价最小 2 ...
- POJ 1026 Cipher(更换)
Cipher Time Limit: 1000MS Memory Li ...
- POJ 1026 Cipher(置换群)
题目链接 题意 :由n个数字组成的密钥,每个数字都不相同,都在1-n之间,有一份长度小于等于n的信息,要求将信息放到密钥下边,一一对应,信息不足n的时候补空格,然后将位置重新排列,将此过程重复k次,求 ...
- poj 1026 Cipher
置换群就可以搞定!!! 注意下格式就好了…… #include<iostream> #include<stdio.h> #include<algorithm> #i ...
- poj 1026(置换群)
题意:给你一个变换规则,和一个字符串,问经过k次变换后得到的字符串. 思路:开始的时候试图去找它的整个周期,谁知道周期太大了,各种RE,后来在得知此题需要用置换群来优化,第一次接触置换群学习了下! 代 ...
- poj 1026
这题一开始没看清楚 等级差距不超过1 1->2->3 就是错误的,因为3-1==2 ,意思是间接的也不行 其次等级最小是1,最大是n 你要到达1号首领的位置 假设1号等级x,限制m,最大上 ...
- poj 3270(置换 循环)
经典的题目,主要还是考思维,之前在想的时候只想到了在一个循环中,每次都用最小的来交换,结果忽略了一种情况,还可以选所有数中最小的来交换一个循环. Cow Sorting Time Limit: 200 ...
- POJ 1026 置换群的k次幂问题
题目大意: 给定了一组对应关系,经过k次幂后,得到新的对应关系b[i],然后将给定的字符串上的第i位字符放置到b[i]的位置上, 如果字符串长度不足n就用空格补足,这里的是空格,也就是str[i] = ...
- [转] POJ数学问题
转自:http://blog.sina.com.cn/s/blog_6635898a0100magq.html 1.burnside定理,polya计数法 这个大家可以看brudildi的<组合 ...
随机推荐
- android 自定义ScrollView实现背景图片伸缩(阻尼效果)
android 自定义ScrollView实现强调内容背景图片伸缩(仿多米,qq空间背景的刷新) 看到一篇文章,自己更改了一下bug: 原文地址:http://www.aiuxian.com/arti ...
- Jmeter读取文件中的值《一》
此篇主要是对应上一章节的呼应,上一篇中讲到将返回值写入文件,这个值如果在下一个接口中用到, 那么我们需要去从文件中读取数据,这是我们该如何操作? 一.测试计划中添加CSV Data Set Confi ...
- hadoop基础教程免费分享
提起Hadoop相信大家还是很陌生的,但大数据呢?大数据可是红遍每一个角落,大数据的到来为我们社会带来三方面变革:思维变革.商业变革.管理变革,各行业将大数据纳入企业日常配置已成必然之势.阿里巴巴创办 ...
- 回收 PV - 每天5分钟玩转 Docker 容器技术(152)
当 PV 不再需要时,可通过删除 PVC 回收. 当 PVC mypvc1 被删除后,我们发现 Kubernetes 启动了一个新 Pod recycler-for-mypv1,这个 Pod 的作用就 ...
- OAuth2.0学习(1-5)授权方式2-简化模式(implicit grant type)
授权方式2-简化模式(implicit grant type) 简化模式(implicit grant type)不通过第三方应用程序的服务器,直接在浏览器中向认证服务器申请令牌,跳过了"授 ...
- 面向对象的PHP(5)
OOP的好处 封装 封装可以隐藏实现细节,使代码模块化,代码重用 继承 继承可以扩展已存在的代码模块(class),代码重用 多态 为了类在继承和派生的时候,保证实例的某一属性正确调用,接口重用 关键 ...
- Codeforces 343D WaterTree - 线段树, DFS序
Description Translated by @Nishikino_Maki from Luogu 行吧是我翻的 Mad scientist Mike has constructed a roo ...
- Web 项目报错No suitable driver found for jdbc:mysql://localhost:3306/book 的一个解决办法
确认jar包加入到了build path中,然后注意版本是否与数据库相配,还要留意将jar包放入WEB-INF下的lib文件夹中
- Java面试题—初级(2)
11.是否可以从一个static方法内部发出对非static方法的调用? 不可以.因为非static方法是要与对象关联在一起的,必须创建一个对象后,才可以在该对象上进行方法调用,而static方法调用 ...
- jquery的ajax全局事件详解
jquery在ajax方面是非常强大和方便的,以下是jquery进行ajax请求时方法模板: $.ajax({ type: "get", url: "" ...