首页 > 其他分享 >暑假牛客多校第二场 2023-7-21

暑假牛客多校第二场 2023-7-21

时间:2023-07-22 16:57:11浏览次数:48  
标签:10 typedef 21 LL mid 多校 牛客 while include

未补完


E. Square


算法:二分

做法:我们依据x来枚举k,得到 \(x * 10^k\) ,用二分在[0, 1e9]查找mid的平方值,且这个值是第一个大于等于 \(x * 10^k\) 的值。得到这个值后我们再判断这个值在除 \(10^k\) 后是否与 \(x\) 相等即可。

code
#include <iostream>
#include <cstring>
#include <algorithm>
#include <vector>
#include <map>
#include <queue>
#include <stack>
#include <deque>
#include <cmath>
#include <string>
#include <set>
#define fir first
#define sec second
using namespace std;

typedef long long LL;
typedef pair<int, int> PII;
typedef pair<double, int> PDI;
typedef pair<double, double> PDD;
int dx[4] = { -1, 1, 0, 0 }, dy[4] = { 0, 0, -1, 1 };

int getlen(LL x)
{
    int cnt = 0;
    while(x)x /= 10, cnt++;
    return cnt;
}

LL sl(LL x)
{
    LL l = 0, r = 1e9;
    while(l < r)
    {
        LL mid = (l + r) / 2;
        if(mid * mid >= x)r = mid;
        else l = mid + 1;
    }
    return l;
}

LL sr(LL x)
{
    LL l = 0, r = 1e9;
    while(l < r)
    {
        LL mid = (l + r + 1) / 2;
        if(mid * mid <= x)l = mid;
        else r = mid - 1;
    }
    return r;
}

void solve()
{
    LL x;
	cin >> x;
	if(x == 0)
    {
        cout << 0 << endl;
        return;
    }

    int len = getlen(x);
    for(int k = 0; k <= 19 - len ; k++)
    {
        LL p = 1;
        for(int i = 1; i <= k ; i++)p = p * 10;

        LL l = sl(x * p);

        LL f = l * l;
        for(int j = 1; j <= k ; j++)f /= 10;
        if(f == x)
        {
            cout << l << endl;
            return;
        }
    }
    cout << "-1" << endl;
}

int main()
{
	ios::sync_with_stdio(false);
	cin.tie(0), cout.tie(0);

	int t;
	cin >> t;
	while (t--)
	{
		solve();
	}

	return 0;
}

标签:10,typedef,21,LL,mid,多校,牛客,while,include
From: https://www.cnblogs.com/dkdklcx/p/17573679.html

相关文章

  • Au2021中文版Audition2021免激活下载 新功能介绍
    AdobeAuditionCS6是一款功能强大的音频编辑器,更是一个专业音频编辑和混合环境。为了方便大家下载使用,winwin7给大家带来的这款AU音频编辑器去除了其他国家的语言,让软件体积变得更小,运行更快,使用更流畅...完善的工具集,其中包含用于创建、混合、编辑和复原音频内容的多轨、波形和光......
  • 2023牛客多校7.21补题
    D-TheGameofEating题意:一共有m道菜,n个人轮流点一道菜,一共点k道。第i个人对第j道菜的喜爱程度\(A_{i,j}\)对所有人公开,一个人点了菜所有人都可以吃到。每个人都希望最大化自己的喜爱程度之和,求最终的点菜集合。分析:很容易想到每个人点菜时都点当前剩下的菜中自己最喜爱的,但是......
  • 7.21总结
    上午不想学习,摆了一上午,中午想起来有个活动需要查资料,然后起来查了一些资料,之后想起来还有原来剪辑的视频需要更改,然后我按照要求稍微更改了一下,让其他部门润色了文案,修改了一下,然后真的啥也不想学,就摆到了晚上,晚上提起了精神,学了会前端,发现跟java差不多,有些api差不多,然乎就睡觉......
  • 牛客暑假多校 2023 第二场
    写在前面比赛地址:https://ac.nowcoder.com/acm/contest/57356。我是MINUS-FIFTEEN级超级战犯。澄清一下,我不是声优厨,我不是声优厨,我不是声优厨。同样是题目选补,我是飞舞。以下个人向难度排序。I签到。随便手玩一下就行。D虽然每个人都倾向于吃到自己最喜欢的菜,但给在......
  • 2023 牛客暑期多校
    7.17我正开,Dgjk倒开,AHJKLMA-AlmostCorrect设\(s\)中\(0\)的下标集合为\(S_{0}\),\(1\)的为\(S_{1}\),最右边的\(0\)的下标\(r\),最左边\(1\)的下标\(l\)。\(s\)没有排好序所以\(l\le|S_{1}|<r\)\(\foralli\inS_{0},(i,r)\)\(\foralli\inS_{1},(l......
  • 2023牛客多校2
    H.0and1inBIT题意给一串操作字符串,其中包含操作\(A,B\):\(A\)代表将二进制每一位反转。\(B\)代表将二进制加\(1\)。且当二进制为全\(1\)时,二进制变为全\(0\)现在包含多次询问,每次询问给定一个区间(区间需要计算得到),给定一个初始二进制\(x\),问你二进制在经过操作字符串对......
  • 2023 暑假牛客多校
    时隔一年,多校又至。还是和jimmywang与shihoghmean组队。只可惜后面要文化课了,可能打不完。只记一些赛时想过的和听完题解后会的妙妙题:7.17“范式杯”2023牛客暑期多校训练营1......
  • 2023.07.21 SMU Summer 2023 Contest Round 5
    2023.07.21SMUSummer2023ContestRound5A.PointsinSegments给n个,1~m的子集,求1~n中所有没在这些子集中出现过的数字把子集区间合并为集合s,输出1~n中没有在s中出现过的数#include"bits/stdc++.h"usingnamespacestd;typedefpair<int,int>PII;intn,m;vector<P......
  • 2024-7-21巅峰极客
    菜鸡打ctf,做了一天牢,算上签到题一共做上两道签到  数学但高中 给出了一大串,一开始没看懂,学姐提醒才知道要画图python太菜,只好手动一个一个粘公式画图网址:https://www.desmos.com/calculator?lang=zh-CN最后生成的图片: 然后试了半天sql没注进去,大佬的代码也没看懂......
  • 2023.7.21
    今天和室友约好早起去跑步了五点半起床 !体验了一下早起的世界,其实外面当时天已经亮了,而且路上已经有了很多人然后和室友打着语音一边唠嗑一边慢跑其实还是蛮开心的,虽然起床很痛苦……明天继续!......