比赛总结:Japan Registry Services (JPRS) Programming Contest 2023 (AtCoder Beginner Contest 324)
比赛:Japan Registry Services (JPRS) Programming Contest 2023 (AtCoder Beginner Contest 324)
A-same
1.常规方法
int main()
{
int n;
cin >> n;
vector<int> s(n);//利用vector容器可以不需要确定内存大小
for (auto &n : s)
{
cin >> n;
}
for (int i = 0; i < n - 1; i++)
{
if (s[i] != s[i + 1])
{
cout << "No" << endl;
return 0;//如果不相等就直接退出程序,否则输出"Yes"
}
}
cout << "Yes" << endl;
return 0;
}
总结:
1.对于这类数组大小动态变化的题目,利用vector容器,就可以动态的改变数组的大小,不需要去确定数组大小,比较方便
2.再main函数中去写,利用return 0;随时退出程序,结束循环。就不需要考虑利用其它变量,在循环结束后再去判断输出内容
3.利用auto &n : s;输入数据,简化代码量(auto缺点:必须遍历完整个容器,无法遍历到某一中间值然后就退出)
2.a faster way
int main()
{
int n, s;
cin >> n >> s;
for (int i = 0; i < n - 1; i++)
{
int s2;
cin >> s2;
if (s2 != s)
{
cout << "No" << endl;
return 0;
}
}
cout << "Yes" << endl;
return 0;
}
总结:
在输入时就做出判断。先输入第一个数,然后通过循环,在每次输入数据时就做出判断,就不需要遍历数组了
其余同常规方法
B - 3-smooth Numbers
1.数学基础
题目中对x,y的限制是整数,但由于给定的数字N>=1,所以并不需要考虑x,y<0,(即if (x<0||y<0);N<1;),proof is under:
1.if we assume that x<0 and y<0,then
0 < N = 2x*3y<1.
so x<0 and y<0 is not satisfied this condition.
2.if we assume that x>0 and y<0,then
N*2xϵ(2k,kϵZ);
3xϵ(2k+1,kϵZ)
it is obvious that equation is fause.in a similar way,if we assume y>0 and x<0,
the equation is fause still.
therefore we have shown if (x<0||y<0),N<1.
2.代码实现
void test01()
{
long long N;//根据所给数据点,需要用long long 来储存
cin >> N;
while (N % 3 == 0)//如果是3的倍数,就除3
{
N /= 3;
}
while (N % 2 == 0)//同理
{
N /= 2;
}
if (N == 1)最后只有1和其他两种情况
{
cout << "Yes" << endl;
}
else
{
cout << "No" << endl;
}
}
总结:利用while,避免了利用for循环的复杂
C - Error Correction
思路:根据题目的操作,可以用输入的string的长度将输入的字符串分为三类,根据三种情况分别进行讨论
void test01()
{
long long n,time = 0,k[999999],q = 0;//注意数据范围
cin >> n;
string t,s;
cin.get();//char ch = getchar();//前面接收了一个数字,缓冲区中还有一个空格,需要清除
getline(cin, t);//利用getline(cin,变量名)去接收一个含有空格的字符串
for (int i = 0; i < n; i++)
{
getline(cin, s);
//如果两string长度相等,那么有两种情况,相等和更改一个字符
if (t.size() == s.size())
{
int a = 2;//利用a去判断有几个字符是不相等的
for (int j = 0; j < t.size(); j++)
{
//根据题意,最多有一个字符不相等,所以当a==0时,即两个点不相等,就退出
if (a == 0)
{
break;
}
if (t[j] != s[j])//不相等就a--
{
a--;
}
//当循环将要结束时,判断是否满足条件
//为防止最后一位才不满足条件,所以要加上a>=1
if (j == t.size() - 1&& a >= 1)
{
time++;//次数加1
k[q] = i + 1;//将下标输入数组中
q++;//数组位置后移
}
}
}
//如果t的长度大于s,那么只能是删除了一个字符
else if(t.size() == s.size()+1)
{
int l = 2;
//用h,j分别控制t和s后移
for (int j = 0,h = 0; j < t.size();h++, j++)
{
if (l == 0)
{
break;
}
if (t[j] != s[h])
{
l--;
//如果到了不相同的那一位,就令s该位不动,j++,然后令s和t的下一位进行比较
h--;
}
if (j == t.size() - 1 && l == 1)
{
time++;
k[q] = i + 1;
q++;
}
}
}
//这种情况同第二种
else if (t.size() == s.size()-1)
{
int m = 2;
for (int j = 0, h = 0; j < t.size(); h++, j++)
{
if (m == 0)
{
break;
}
if (t[j] != s[h])
{
m--;
j--;
}
if (j == t.size() - 1 && m>= 1)
{
time++;
k[q] = i + 1;
q++;
}
}
}
}
//正常输出
cout << time << endl;
for (int i = 0; i < q; i++)
{
cout << k[i] << ' ';
}
}
D - Square Permutation
思路:题目中说明最终要得到的数是一个完全平方数,那就列举10000000以内的平方数,看他们是否可以由输入的四个数字经过全排列得到
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
#include <cstring>
#include <stdlib.h>
#include <stdio.h>
#include <math.h>
#include <iomanip>
#include <ctype.h>
#include <ctime>
#include <stack>
#include <list>
#include <queue>
#include <algorithm>
using namespace std;
//n:输入的数字个数,bug:储存输入数字中含有数字1-9的个数,dig:储存完全平方数中含有数字1-9的个数,ans:结果
int n, dig[10], bug[10],ans;
string s;
int main()
{
ios::sync_with_stdio(false);
cin >> n >> s;//因为输入的各个数据是连续输入,所以用字符串进行储存
for (int i = 0; i < n; i++)
{
bug[s[i]%48]++;//利用ASCII将每一个字符转化为数字
}
//因为数据上限是10的13次方,所以循环到10的7次就结束循环
for (int i = 0; i < 10000000; i++)
{
memset(dig, 0, sizeof(dig));//初始化dig数组为0
//利用i*i构建完全平方数
//(1)因为数据上限超出int类型,所以用long long 去储存
//(2)为防止数据越界,所以先将i转化为long long 类型,然后再进行计算
//(3)注意要先将i转化为long long 类型,所以要用1ll*i*i,而不是i*i*1ll;
//第二种方式在计算i*i时就已经炸掉了,这时再去转化为long long 类型就已经没用了
long long x = 1ll*i * i;
//下面去获取每一位数字
/*这里有一个细节,我默认的位数就是字符串的长度,所以当x的长度小于默认位数时,就会多记录0的个数,然而因为数字位数不相等时结论肯定不成立,所以该种情况并不需要特殊考虑*/
for (int j = 0; j <n; j++)
{
dig[x % 10]++;
x /= 10;
}
if (x)continue;//if(x!=0)也就是x不等于0,就不去进行下面的判断
for (int k = 0; k < 10; k++)
{
if (dig[k] != bug[k])
{
ans--;//如果不满足,就ans--;使ans的值不被改变
break;
}
}
ans++;//如果上面的循环不退出循环,也就是相等,就对ans++
}
cout << ans << endl;
return 0;
}
比赛总结:Japan Registry Services (JPRS) Programming Contest 2023 (AtCoder Beginner Contest 324)的更多相关文章
- M-SOLUTIONS Programming Contest 2021(AtCoder Beginner Contest 232) 题解
目录 G - Modulo Shortest Path H - King's Tour 因为偷懒就只写G和H的题解了. G - Modulo Shortest Path 首先可以观察到对于一条从点\( ...
- AtCoder Beginner Contest 076
A - Rating Goal Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Takaha ...
- atcoder beginner contest 251(D-E)
Tasks - Panasonic Programming Contest 2022(AtCoder Beginner Contest 251)\ D - At Most 3 (Contestant ...
- AtCoder Beginner Contest 100 2018/06/16
A - Happy Birthday! Time limit : 2sec / Memory limit : 1000MB Score: 100 points Problem Statement E8 ...
- KYOCERA Programming Contest 2021(AtCoder Beginner Contest 200) 题解
KYOCERA Programming Contest 2021(AtCoder Beginner Contest 200) 题解 哦淦我已经菜到被ABC吊打了. A - Century 首先把当前年 ...
- AtCoder Beginner Contest 184 题解
AtCoder Beginner Contest 184 题解 目录 AtCoder Beginner Contest 184 题解 A - Determinant B - Quizzes C - S ...
- AtCoder Beginner Contest 053 ABCD题
A - ABC/ARC Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement Smeke has ...
- AtCoder Beginner Contest 151 题解报告
总的来说,这次的题目比较水,然而菜菜的我并没有把所有题目都做完,话不多说,直接来干货: A:Next Alphabet 题目链接:https://atcoder.jp/contests/abc151/ ...
- AtCoder Beginner Contest 068 ABCD题
A - ABCxxx Time limit : 2sec / Memory limit : 256MB Score : 100 points Problem Statement This contes ...
- AtCoder Beginner Contest 154 题解
人生第一场 AtCoder,纪念一下 话说年后的 AtCoder 比赛怎么这么少啊(大雾 AtCoder Beginner Contest 154 题解 A - Remaining Balls We ...
随机推荐
- Linux系统运维之Web服务器Nginx安装
一.介绍 Nginx是一款轻量级的Web 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器,并在一个BSD-like 协议下发行.本文先整理web服务器内容. 二.环境及软件版本 操作 ...
- CentOS 8搭建Kubernetes-k8s集群-1.18.5
目录 环境配置 服务器信息 软件版本 环境正确性 端口正常开放 kube-master节点端口 kube-node节点端口 配置主机互信 配置hosts映射 配置ssh密钥 禁用swap 关闭SELi ...
- 【Shell】数组
数组 bash 只支持一维数组. 数组下标从 0 开始,下标可以是整数或算术表达式,其值应大于或等于 0. 创建数组 # 创建数组的不同方式 nums=([2]=2 [0]=0 [1]=1) colo ...
- 2023年郑州轻工业大学校赛邀请赛clk
需要总结的地方挺多的,首先是题目一次通过率有待提高,对于一些特别的样例还要加以分析,算法熟练的不高,不能清晰的看出在哪道题考什么算法,就比如兔子爱吃萝卜那道题,就是一个背包问题,比较基础,但是我们团队 ...
- Centos7 安装部署 Kubernetes(k8s) 高可用集群
目录 一.系统环境 二.前言 三.Kubernetes(k8s)高可用简介 四.配置机器基本环境 五.部署haproxy负载均衡器 六.部署etcd集群 七.部署Kubernetes(k8s) mas ...
- 如何新建一个django项目
1.新建项目 2选择django 3.接下来我们进入 djangotest目录输入以下命令,启动服务器: python manage.py runserver 0.0.0.0:8000 0.0.0.0 ...
- React报错:This is probably not a problem with npm. There is likely additional logging output above.
解决方案 删除node_modules和package-lock.json,之后运行npm cache clear --force,重新安装模块npm install,另外要注意 npm 5.0版本之 ...
- 手写promise之分步解析
promise是es6推出适用于异步请求的构造函数,帮助解决回调地狱的问题,以下内容将自定义实现promise,只包括基本使用,所以一些边界情况考虑没有在内. 如果对promise用法还不熟悉的朋友可 ...
- c++算法之离散化
什么是离散化? 离散化,故离散数学,其中的"离散"就是不连续的意思.离散化可以保持原数值之间相对大小关系不变的情况下将其映射成正整数. 也就是给可能用到的数值按大小关系分配一个编号 ...
- 《SQLi-Labs》01. Less 1~5
@ 目录 前言 索引 Less-1 题解 原理 Less-2 题解 Less-3 题解 Less-4 题解 Less-5 题解 原理 sqli.开启新坑. 前言 对于新手,为了更加直观的看到 sql ...