【链接】 我是链接,点我呀:)

【题意】

题意

【题解】

设cnt表示s1和s2不同的字符的个数
如果cnt>2*t
因为这cnt个位置肯定至少有一边不同
显然肯定会有一个f(s,S)的值大于t的
如果t

【代码】

import java.io.*;
import java.util.*; public class Main { static InputReader in;
static PrintWriter out; public static void main(String[] args) throws IOException{
//InputStream ins = new FileInputStream("E:\\rush.txt");
InputStream ins = System.in;
in = new InputReader(ins);
out = new PrintWriter(System.out);
//code start from here
new Task().solve(in, out);
out.close();
} static int N = 50000;
static class Task{ int n,t;
String s1,s2;
StringBuilder sb;
int cnt = 0; public char v(char x,char y) {
for (char key = 'a';key<='z';key++){
if (key!=x && key!=y) return key;
}
return '2';
} public void solve(InputReader in,PrintWriter out) {
n = in.nextInt();t = in.nextInt();
s1 = in.next();s2 = in.next();
for (int i = 0;i < n;i++) {
if (s1.charAt(i)!=s2.charAt(i)) {
cnt++;
}
}
if (cnt>2*t) {
out.println(-1);
return;
}
if (cnt>=t) {
int num = cnt-t;
int cl = 0;
for (int i = 0;i < n;i++) {
if (s1.charAt(i)==s2.charAt(i)) {
out.print(s1.charAt(i));
}else {
cl++;
if (cl<=num) {
out.print(s2.charAt(i));
}else if (cl>num && cl <=2*num) {
out.print(s1.charAt(i));
}else {
out.print(v(s1.charAt(i),s2.charAt(i)));
}
}
}
}else {
int num = t-cnt;
for (int i = 0;i < n;i++) {
if (s1.charAt(i)==s2.charAt(i)) {
if (num>0) {
num--;
out.print(v(s1.charAt(i),s2.charAt(i)));
}else {
out.print(s1.charAt(i));
}
}else {
out.print(v(s1.charAt(i),s2.charAt(i)));
}
}
}
}
} static class InputReader{
public BufferedReader br;
public StringTokenizer tokenizer; public InputReader(InputStream ins) {
br = new BufferedReader(new InputStreamReader(ins));
tokenizer = null;
} public String next(){
while (tokenizer==null || !tokenizer.hasMoreTokens()) {
try {
tokenizer = new StringTokenizer(br.readLine());
}catch(IOException e) {
throw new RuntimeException(e);
}
}
return tokenizer.nextToken();
} public int nextInt() {
return Integer.parseInt(next());
}
}
}

最新文章

  1. .NET程序员走向高端必读书单汇总
  2. RabbitMQ学习: 介绍
  3. iOS UIViewController 和 nib 相关的3个方法
  4. The 2015 China Collegiate Programming Contest H. Sudoku hdu 5547
  5. Linux信号处理1
  6. android 访问SMS短信收件箱
  7. aspx向silverlight传值
  8. Azure China
  9. 使用File、Path和Directory进行常见的操作
  10. 「LibreOJ NOIP Round #1」旅游路线
  11. JavaScript 原型链学习(一)原型对象
  12. !! MACD战法总结
  13. ORACLE 监听配置
  14. V-rep学习笔记:vrep中的实用工具
  15. Netbeans8.1设置Consola字体并解决中文乱码问题
  16. java 线程的简单理解
  17. 接口调用 POST
  18. win7无线网络共享
  19. dukuwiki简单教程
  20. ref:ThinkPHP Builder.php SQL注入漏洞(&lt;= 3.2.3)

热门文章

  1. FJOI2019退役记
  2. O - Combinations (组合数学)
  3. kafka启动时出现FATAL Fatal error during KafkaServer startup. Prepare to shutdown (kafka.server.KafkaServer) java.io.IOException: Permission denied错误解决办法(图文详解)
  4. struct结构的一些内容
  5. Myeclipse2014安装&amp;破解激活
  6. Java编程思想读书笔记_第6章(访问权限)
  7. WordPress主题reBorn最新破解版发布
  8. JavaScript(八)日期对象
  9. Jmeter的属性和变量
  10. BZOJ 3884: 上帝与集合的正确用法 扩展欧拉定理 + 快速幂