zoukankan      html  css  js  c++  java
  • Educational Codeforces Round 102 (Rated for Div. 2) B. String LCM (构造,思维)

    • 题意:给你两个字符串(a)(b),找出它们的(lcm),即构造一个新的字符串(c),使得(c)可以由(x)(a)得到,并且可以由(y)(b)得到,输出(c),如果(c)不存在,输出(-1).
    • 题解:我们可以根据(a)(b)的长度得出(c)的长度(len_c),而(len_c)一定是(len_a)(len_b)的倍数, 我们就可以根据这个倍数关系构造出(c)(用(a)或者(b)构造都行,因为假如合法的话,它们两个一定都是满足的),然后跑个循环check一下就好了.
    • 代码:
    #include <bits/stdc++.h>
    #define ll long long
    #define fi first
    #define se second
    #define pb push_back
    #define me memset
    #define rep(a,b,c) for(int a=b;a<=c;++a)
    #define per(a,b,c) for(int a=b;a>=c;--a)
    const int N = 1e6 + 10;
    const int mod = 1e9 + 7;
    const int INF = 0x3f3f3f3f;
    using namespace std;
    typedef pair<int,int> PII;
    typedef pair<ll,ll> PLL;
    ll gcd(ll a,ll b) {return b?gcd(b,a%b):a;}
    ll lcm(ll a,ll b) {return a/gcd(a,b)*b;}
    
    int __;
    string s,t;
    
    int main() {
        ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
    	
    	cin>>__;
    	while(__--){
    		cin>>s>>t;
    
    		int len1=(int)s.size();
    		int len2=(int)t.size();
    
    		if(len1<len2){
    			swap(s,t);
    			swap(len1,len2);
    		}
    		
    		int cur=lcm(len1,len2)/len2;
    
    		string tmp="";
    
    		rep(i,1,cur){
    			tmp+=t;
    		}
    
    		bool flag=true;
    
    		int i=0;
    		while(i<(int)tmp.size()){
    			rep(j,0,len1-1){
    				if(tmp[i]!=s[j]){
    					flag=false;
    					break;
    				}
    				i++;
    			}
    			if(!flag) break;
    		}
    
    		if(flag) cout<<tmp<<'
    ';
    		else cout<<"-1
    ";
    
    	}
    	
    
    
        return 0;
    }
    
    
  • 相关阅读:
    unity编辑器脚本工具练习
    虚拟现实之机械拆装项目架构
    unity两点之间抛物线,完美金手指
    unity发射弓箭轨迹的实现
    基于unity的直升机模拟设计
    windows使用小技巧
    硬盘分区表知识——详解硬盘MBR
    针对设备转发表的攻击
    kali2020创建root用户
    OllyDBG的基本快捷键及其功能
  • 原文地址:https://www.cnblogs.com/lr599909928/p/14289337.html
Copyright © 2011-2022 走看看