A. Doggo Recoloring

题目意思是给一个字符串(都是小写字母),如果有两个字符相同,我们可以将这两个字符变成其他字符,问能不能使字符串字母都一样

思路  有两个相同字符时就能;  字符串长度为1时也可以。

#include<bits/stdc++.h>
#define int long long
#define MAX(a,b,c) max(a,max(b,c))
#define MIN(a,b,c) min(a,min(b,c))
#define pb push_back
#define fi first
#define se second
typedef long long ll;
typedef long long LL;
typedef unsigned long long ull;
typedef unsigned long long uLL;
using namespace std;
const int maxn=3e6+;
const int INF=0x3f3f3f3f;
map<char,int> mp;
int32_t main()
{
int n; cin>>n;
if(n==) {cout<<"YES"<<endl; return ;}
string ss; cin>>ss;
int t=;
for(int i=;i<n;i++)
{
mp[ss[i]]++;
if(mp[ss[i]]==)
{
t=; break;
}
}if(t) cout<<"YES"<<endl; else cout<<"NO"<<endl;
}

A.cpp

B. Weakened Common Divisor

给你n对数字,让你求一个数  是每一对数中两个中任意一个数的非1因子;

有的话直接输出那个数,没有输出-1;

给出n<=1e5+5e4; ai,bi<=2e9;

直接找ai, bi 的因子  再看是不是 其他对数的因子,分析一下   n为1e5;

1e9 只有99个;  但是有一组很强的数据  735134400 1396755360    有2456 个因子(没有重复的)  直接超时了; cf 测评机太强了   改了一下  1.4s过了这个第45点。

最后还是超时在第84个点了

#pragma once
#include<iostream>
#include<cstdio>
using namespace std;
const int maxn=2e5+;
int vs[maxn];
int main()
{
int n; scanf("%d",&n);
int a,b;
int t=;
for(int i=;i<=n;i++)
{
scanf("%d %d",&a,&b);
if(i==)
{
int j;
for(j=;j*j<=a||j*j<=b;j++)
{
if(a%j==&&a/j!=) vs[++t]=a/j;
if(b%j==&&b/j!=) vs[++t]=b/j;
if( (b%j==||a%j==)&&j!=) vs[++t]=j;
}
}
else
{
int x=;
for(int j=;j<=t;j++)
{
if( (a>=vs[j]&&a%vs[j]==)||(b>=vs[j]&&b%vs[j]==) )
{
vs[++x]=vs[j];
}
}
t=x;
}
if(t==) { printf("%d\n",-); return ;}
}printf("%d\n",vs[]);
}

超时代码

再来考虑   2456 个因子  如果有 2 3   再来个 6 这样的数就不用放了,所以我们只要把质因数放进去就行了。

求2456个数的素因子;  应该是可以的;

#pragma once
#include<iostream>
#include<cstdio>
using namespace std;
const int maxn=2e5+;
int vs[maxn];
int main()
{
int n; scanf("%d",&n);
int a,b;
int t=;
for(int i=;i<=n;i++)
{
scanf("%d %d",&a,&b);
if(i==)
{
int j;
for(j=;j*j<=a||j*j<=b;j++)
{
if(a%j==&&a/j!=) vs[++t]=a/j;
if(b%j==&&b/j!=) vs[++t]=b/j;
if( (b%j==||a%j==)&&j!=) vs[++t]=j;
}
sort(vs+,vs+t+);
int x=;
for(int j=;j<=t;j++)
{
int w=;
for(int c=;c*c<=t;c++)
{ }
}
}
else
{
int x=;
for(int j=;j<=t;j++)
{
if( (a>=vs[j]&&a%vs[j]==)||(b>=vs[j]&&b%vs[j]==) )
{
vs[++x]=vs[j];
}
}
t=x;
}
cout<<t<<endl;
if(t==) { printf("%d\n",-); return ;}
}printf("%d\n",vs[]);
}

未完成代码

这个思路做不到的话  还有一个思路;

拿 17 18  为例子  他们的因数  2 3 6 9 18 1 17; 都是17*18的因数;

15  24来说   2 3 4 5 6 8 12 15 24    是 15*24的因数  或者说  15*24/gcd(15,24);

这两个例子的  最大公约数  gcd(17*18,15*24)=18;   即 17*18  与 25*24 不互质  存在一个约数;

所以n组 gcd的值不为1,为x>1;  就有约束 ;  还是x的因数;

是不是我们输出 x 就行了   答案是否;例如  2  17  2  17 ;答案是 2 或 14, 不是34;

我们就从2-sqrt(x)找因数  找不到才是gcd的值; 尽管这样  2-sqrt(x)的值还是很大;

要进一步缩小       g=max(gcd(g,a[1]),gcd(g,b[1]))   就有了和第一组数比较  ;

#include<bits/stdc++.h>
#define int long long
#define MAX(a,b,c) max(a,max(b,c))
#define MIN(a,b,c) min(a,min(b,c))
#define pb push_back
#define fi first
#define se second
typedef long long ll;
typedef long long LL;
typedef unsigned long long ull;
typedef unsigned long long uLL;
using namespace std;
const int maxn=2e5+;
const int INF=0x3f3f3f3f;
int a[maxn];
int b[maxn];
int gcd(int a,int b){return b ? gcd(b, a%b): a; }
int32_t main()
{
int n; scanf("%lld",&n); int g=;
for(int i=;i<=n;i++)
{
scanf("%lld %lld",&a[i],&b[i]);
if(i==) g=a[i]*b[i];
else g=gcd(g,a[i]*b[i]);
} if(g==) { cout<<-<<endl; return ; }
g=max(gcd(g,a[]),gcd(g,b[]));//cout<<g<<endl;
for(int i=;i*i<=g;i++)
{
if(g%i==) {cout<<i<<endl; return ;}
}
cout<<g<<endl; return ;
}

B.cpp AC代码

C. Plasticine zebra

给你一个字符串    每一个点  我们可以执行   左边分别 第一个和最后一个。第二个和倒数第二个,第三.....。互换。右边也一样;然后把左边移到右边, 问你wb这样连续的字母最大有多少;

其实每次操作都是头尾相连 中间断开 ;  没看出来的可以倒看;

最后就是一个环 上找一点断开;找那个点断开  wb这样连续字母最大之

几个hack数据   bbbb  1     wbwb  4

#include<bits/stdc++.h>
#define int long long
#define MAX(a,b,c) max(a,max(b,c))
#define MIN(a,b,c) min(a,min(b,c))
#define pb push_back
#define fi first
#define se second
typedef long long ll;
typedef long long LL;
typedef unsigned long long ull;
typedef unsigned long long uLL;
using namespace std;
const int maxn=3e6+;
const int INF=0x3f3f3f3f;
int32_t main()
{
string ss; cin>>ss; int k=ss.size();
ss=ss+ss;
int ans=;
int num=;
for(int i=;i<ss.size()-;i++)
{
if(ss[i]!=ss[i+]) num++;
else num=;
ans=max(ans,num);
}
cout<<min(k,ans)<<endl;
}

C.cpp

#505 1&2 A-C 后面未完成的更多相关文章

  1. [占位-未完成]scikit-learn一般实例之十一:异构数据源的特征联合

    [占位-未完成]scikit-learn一般实例之十一:异构数据源的特征联合 Datasets can often contain components of that require differe ...

  2. [占位-未完成]scikit-learn一般实例之十:核岭回归和SVR的比较

    [占位-未完成]scikit-learn一般实例之十:核岭回归和SVR的比较

  3. PIC12F508/505/509/510/506/519/526/527单片机破解芯片解密方法!

    IC芯片解密PIC12F508/505/509/510/506/519/526/527单片机破解 单片机芯片解密型号: PIC12F508解密 | PIC12F505解密 | PIC12F506解密  ...

  4. 1Z0-053 争议题目解析505

    1Z0-053 争议题目解析505 考试科目:1Z0-053 题库版本:V13.02 题库中原题为: 505.You configured the default backup device type ...

  5. 解决java代码测试http协议505错误

    代码功能:通过java代码获取网页源代码: 所用工具:Myclipse8.5+tomcat6.0+浏览器 系统环境:windows xp旗舰版 火狐浏览器版本: IE浏览器版本: 测试http协议有错 ...

  6. 经验总结:HTTP返回505错误小记

    昨天调试代码的时候,用http请求一个图片,返回的结果为如下: HTTP/1.1 505 HTTP Version Not Supported Server: Apache-Coyote/1.1 Da ...

  7. HTTP错误大全 404 200 501 502 505

    HTTP错误 大全 403 401 400 404 304 200 HTTP 400 - 请求无效 HTTP 401.1 - 未授权:登录失败 HTTP 401.2 - 未授权:服务器配置问题导致登录 ...

  8. [未完成]WebService学习第一天学习笔记

    [未完成]WebService学习第一天学习笔记[未完成]WebService学习第一天学习笔记

  9. [未完成]关于GUI Java图形化界

    "笔记内容完成,整体未完成" GUI 图形化用户界面 用java做图形化用户界面的程序不多,大多用C++和defy.因为,Java做图形化效率低. 首先你要安装一个虚拟机,C++是 ...

随机推荐

  1. 【框架】PageObject(一)

    1.目的:为了将元素的find方法和业务逻辑分开来.如果元素的页面位置发生了变化,只需改动一个文件,而不影响业务的实现. 2.原理:一般一个页面对应一个class,在class里描述所有要用到的web ...

  2. 学习Linux系统的方法有很多,适合自己的才是最好

    综观现在互联网+的发展以及应用,作为一个从事IT行业的人员,应该懂得Linux占比多大份量,所以说,去掌握Linux是一种相当重要的谋生途径,当然,如果你对它产生情感那更好.这篇文章主要是本人结合自身 ...

  3. javascript 跑马灯

    1.看了写跑马灯的教程案例,隔了段时间自己写了一个简单的跑马灯.将过程中遇到的问题特此记录下来 代码如下: <!DOCTYPE html> <html> <head> ...

  4. MySQL字符集与校对

    一.什么是字符集与校对 1.字符集与校对 字符集是指一种从二进制编码到某种字符符号的映射. 校队是指一组用于某个字符集的配许规则. 2.utf8与utf8mb4 标准的UTF-8字符集编码是可以使用1 ...

  5. day22 模块_1

    核能来袭--模块 1.简单了解模块 2.Collections 3.Time模块 4.functools 一.初识模块 其实之前写的每一个PY文件都是一个模块 还有一些我们一直在使用的模块  buil ...

  6. spring有关jar包的作用

    参考的是spring官网spring4.3版本. 链接:https://docs.spring.io/spring/docs/4.3.19.RELEASE/spring-framework-refer ...

  7. pragma comment的使用 pragma预处理指令详解

    pragma comment的使用 pragma预处理指令详解   #pragma comment( comment-type [,"commentstring"] ) 该宏放置一 ...

  8. C代码与C++代码之间的相互调用

    1.showCpp.cpp #include <iostream> using namespace std; // 声明为C语言可以调用的函数 extern "C" v ...

  9. Nginx 自动补全url地址补全最后的斜线

    参考地址: http://blog.csdn.net/dong123dddd/article/details/51660368 location /riskcontrol { root /data; ...

  10. 句柄线程做参数和PostMessage的用法

    当我们启动一个线程,并且要给线程函数传递的参数是窗口句柄时,我们应该这样做: HWND hHwnd = GetSafeHwnd(); HANDLE hThread; DWORd dwThreadId; ...