zoukankan      html  css  js  c++  java
  • [每日一题2020.06.10]Codeforces Round #644 (Div. 3) ABCDEFG

    花了5个多少小时总算把div3打通一次(

    题目链接

    problem A

    题意 : 两个x*y的矩形不能重叠摆放, 要放进一个正方形正方形边长最小为多少

    先求n = min(2x, 2y, x+y)

    再求max(n, x, y)即为正方形边长

    /*
     * Author: RoccoShi
     * Time: 2020-06-10 20:05:02
    */
    
    #include <bits/stdc++.h>
    using namespace std;
    
    typedef long long ll;
    
    int main() {
        ios::sync_with_stdio(false);
        cin.tie(0);
        int t;
        cin >> t;
        while (t--) {
        	int x, y;
        	cin >> x >> y;
        	int minn = min(x+x, y+y);
        	minn = min(minn, x+y); 	
        	int ans = max(minn, x);
        	cout << pow(max(ans, y),2) << endl;
        }
        return 0;
    }
    

    problem B

    题意 : 找一个数组排序后相邻最小的两个数

    排序后扫一遍

    /*
     * Author: RoccoShi
     * Time: 2020-06-10 20:05:02
    */
    
    #include <bits/stdc++.h>
    using namespace std;
    
    typedef long long ll;
    
    int team[55];
    int main() {
        ios::sync_with_stdio(false);
        cin.tie(0);
        int t;
        cin >> t;
        while (t--) {
        	int n;
        	cin >> n;
        	int minn = 9999;
        	for (int i = 0; i < n; ++i)
        	{
        		cin >> team[i];
        	}
        	sort(team, team + n);
        	for (int i = 1; i < n; ++i)
        	{
        		if (minn > team[i]-team[i-1]) {
        			minn = team[i]-team[i-1];
        		}
        	}
        	cout << minn <<endl;
        }
        return 0;
    }
    

    problemC

    题意 :

    规则1 : 两个奇数或者两个偶数可以组一个team

    规则2 : 相差为1的两个数可以组一个team

    问 : 所有编号能否全部组成team

    分别统计奇数和偶数的个数, 相差为1的两个数必为奇数和偶数

    奇数和偶数的个数有两种情况 :

    1. 均为奇数
    2. 均为偶数

    第二种必可以, 第一种只要有一对以上的规则2就可以变为第二种

    /*
     * Author: RoccoShi
     * Time: 2020-06-10 20:05:02
    */
    
    #include <bits/stdc++.h>
    using namespace std;
    
    typedef long long ll;
    
    int a[55];
    
    int main() {
        ios::sync_with_stdio(false);
        cin.tie(0);
        int t;
        cin >> t;
        while (t--) {
        	int n;
        	cin >> n;
        	int cntodd = 0, cnteven = 0, cntpair = 0;
        	for (int i = 0; i < n; ++i) {
        		cin >> a[i];
        		if (a[i] % 2 == 1)
        			cntodd++;
        		else 
        			cnteven++;
        	}
        	sort(a, a+n);
        	for (int i = 1; i < n; ++i)
        	{
        		if(a[i]-a[i-1]==1){
        			cntpair++;
        			i++;
        		}
        	}
        	if(cnteven % 2 == 1 && cntodd % 2 ==1 ) {
        		if(!cntpair)
        			cout << "NO" <<endl;
        		else
        			cout << "YES" << endl;
        	}
        	else
        		cout<< "YES" <<endl;
        }
        return 0;
    }
    

    problem D

    题意 :

    找一个数n的所有因数里小于等于k的最大值

    这题想了好久啊....

    首先, 找一个数的因数 不用! 遍历! 所有! 数!

    只需要把i从1遍历到(sqrt{n}) 就可以了!

    如果n可以整除i, 那么因数有两个, 一个是n/i, 还有一个是i

    比如8, 我们遍历1,2就可以得到因数 1, 2, 4, 8

    接下来只需要判断这个数是否<=k即可

    如果k大于等于n, 直接输出1就可以了

    /*
     * Author: RoccoShi
     * Time: 2020-06-10 20:05:02
    */
    
    #include <bits/stdc++.h>
    using namespace std;
    
    typedef long long ll;
    
    int main() {
        ios::sync_with_stdio(false);
        cin.tie(0);
        int t;
        cin >> t;
        while (t--) {
        	int n, k;
        	cin >> n >> k;
        	if ( k >= n) {
        		cout << 1 << endl;
        	}
        	else 
        	{
        		int m  = sqrt(n);
        		int ans = n;
        		for (int i = m; i >= 1; --i) // 叉子的个数
        		{
        			if(n % i == 0){
        				if(i <= k) ans = min(ans, n/i);
        				if(n/i <= k) ans = min(ans, i);	// 想了好久啊烦
        			}
        		}
        		cout << ans << endl;
        	}
        }
        return 0;
    }
    

    problem E

    题意 : 俄罗斯方块类, n*n的正方形上面和左边各有n个发射口, 发射顺序自定义, 1为该处有个块, 0为没有. 问是否能堆叠成给定的形状

    扫描一波判断所有的1下面或者右边是否有个0, 如果都莫得直接输出NO

    /*
     * Author: RoccoShi
     * Time: 2020-06-10 20:05:02
    */
    
    #include <bits/stdc++.h>
    using namespace std;
    
    typedef long long ll;
    
    int x[55][55];
    
    int main() {
        ios::sync_with_stdio(false);
        cin.tie(0);
        int t;
        cin >> t;
        while (t--) {
        	int n;
        	cin >> n;
        	bool flag = 1;
        	char s;
        	cin.get();
        	for (int i = 0; i < n; ++i)
        	{
        		for (int j = 0; j < n; ++j)
        		{
        			s = cin.get();
        			//cout.put(s);
        			x[i][j] = s=='0'?0:1;
        		}  	
        		s=cin.get();
        		//cout.put(s);
        	}
    
        	for (int i = 0; i < n; ++i)
        	{
        		for (int j = 0; j < n; ++j)
        		{
        			if(i == n-1 || j == n-1)
        				continue;
        			else if(x[i][j] == 1)
        			{
        				if((x[i][j+1] || x[i+1][j]) == 0)
        					flag = 0;
        			}
        		}
        	}
        	if(flag)
        		cout << "YES" << endl;
        	else
        		cout << "NO" << endl;
        }
        return 0;
    }
    

    problem F

    题意 : 给n个字符串问是否存在一个字符串与每个字符串都只有一个地方不同

    给定范围很小, 考虑直接暴力, 最大遍历不过为(10 imes 10 imes 26)

    直接把字符串存起, 然后遍历判断

    /*
     * Author: RoccoShi
     * Time: 2020-06-10 20:05:02
    */
    
    #include <bits/stdc++.h>
    using namespace std;
    
    typedef long long ll;
    
    vector<string> s(15);
    string x(15, '');
    int m, n;
    
    bool is1(){
    	for (int i = 0; i < n; ++i)
    	{
    		int cnt = 0;
    		for (int j = 0; j < m; ++j)
    		{
    			cnt += (x[j] == s[i][j] ? 0 : 1 );
    		}
    		if(cnt > 1)
    			return false;
    	}
    	return true;
    }
    
    int main() {
        ios::sync_with_stdio(false);
        cin.tie(0);
        int t;
        cin >> t;
        while(t--) {
        	bool flag = false;
        	cin >> n >> m;
        	for (int i = 0; i < n; ++i) 
        		cin >> s[i];
        	for (int i = 0; i < m; ++i)
        	{
        		x[i] = s[0][i];
        	}
        	for (int i = 0; i < m; ++i)
        	{
        		for (int j = 'a'; j <= 'z'; ++j) {
        			x[i] = j;
        			if(is1()){
        				flag = true;
        				break;
        			}
        		}
        		if(flag)
        			break;		
    			x[i] = s[0][i];
    		}
    		if(flag == 1) {
    			for (int i = 0; i < m; ++i)
    			{
    				cout<< x[i];
    			}
    			cout << endl;
    		}
    		else
    			cout << "-1" << endl;
    	}
        return 0;
    }
    

    problem G

    题意 : 给定n*m的矩阵和数字a, b. 问是否存在每行有a个1且每列有b个1的排列

    首先判断是否(n imes a = b imes m) , 如果是那么必存在这样的排列

    怎么排? 循环排列即可

    比如n = 4, m = 6, a = 3, b = 2

    111000

    000111

    111000

    000111

    /*
     * Author: RoccoShi
     * Time: 2020-06-10 20:05:02
    */
    
    #include <bits/stdc++.h>
    using namespace std;
    
    typedef long long ll;
    
    const int maxn = 55;
    int mp[maxn][maxn];
    
    int main() {
        ios::sync_with_stdio(false);
        cin.tie(0);
        int t;
        cin >> t;
     	int n, a, m, b;
        while(t--) {
    	    cin >> n >> m >> a >> b;
    	    if(n*a != m*b)
    	    {
    	    	cout << "NO" << endl;
    	    }
    	    else 
    	    {
    	    	cout << "YES" << endl;
    		    int pos = 0;
    		    for (int i = 0; i < n; ++i)
    		    {
    		    	for (int j = 0; j < a; ++j)
    		    	{
    					 mp[i][pos++] = 1;
    					 pos %= m;
    		    	}
    		    }
    		    for (int i = 0; i < n; ++i)
    		    {
    		    	for (int j = 0; j < m; ++j) {
    		    		cout << mp[i][j];
    		    		mp[i][j] = 0;
    		    	}
    		    	cout << endl;
    		    }
    		}
    	}
    	return 0;
    }
    
  • 相关阅读:
    前端知识点(1)
    js防抖和节流
    react生命周期方法有哪些?
    vue音乐播放器
    vue天气查询
    vue+axios安装
    vue 实现todolist,包含添加,删除,统计,清空,隐藏功能
    vue简单计数器
    手动搭建的react环境中,关于图片引入的问题
    promise封装ajax
  • 原文地址:https://www.cnblogs.com/roccoshi/p/13090346.html
Copyright © 2011-2022 走看看