zoukankan      html  css  js  c++  java
  • 【Codeforces 584C】Marina and Vasya

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

    题意

    【题解】

    设cnt表示s1和s2不同的字符的个数 如果cnt>2*t 因为这cnt个位置肯定至少有一边不同 显然肯定会有一个f(s,S)的值大于t的 如果t<=cnt<=2*t 这种情况,不能全都让这cnt个位置s1和s2都与所求s不同 因为每个都会多出来cnt-t个 我们可以这样,从cnt中选出来cnt-t个位置,只让s1与s不同 然后再求出来cnt-t个位置,只让s2与s不同 这样f(s1,S)和f(s2,S)的值都为cnt-t了 还剩下cnt-(cnt-t)*2 =-cnt+2*t个不同的位置 让这些位置s1,s2的字符都跟S不同 那么f(s1,S)和f(s2,S)的值就都加上-cnt+2*t了 也即变成cnt-t+-cnt+2*t=t 刚好符合题意 (就是想办法把多余的部分抵消掉) cnt

    【代码】

    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());
            }
        }
    }
    
  • 相关阅读:
    jq判断鼠标滚轴向上滚动还是向下滚动
    Directory 中user Var 如何添加到通道变量中?
    Centos 6.5 freeswitch 编译mod_shout
    golang esl api
    opensips redis配置记录
    luasocket 安装记录 (FS1.4)
    luasocket 安装记录 (FS1.6)
    Callcenter 模块解析
    OpenSIPS 1.11.1安装记录
    阿里服务器挂载数据盘
  • 原文地址:https://www.cnblogs.com/AWCXV/p/10591253.html
Copyright © 2011-2022 走看看