A.QAQ

  • 题目大意:从给定的字符串中找出QAQ的个数,三个字母的位置可以不连续
  • 思路:暴力求解,先找到A的位置,往前扫,往后扫寻找Q的个数q1,q2,然
  • 后相乘得到q1*q2,这就是这个A能够找到的QAQ个数,依次累加即可
#include <bits/stdc++.h>
using namespace std;
int main() {
ios::sync_with_stdio(false);
cin.tie(0);
cout.tie(0);
string s;
cin>>s;
int len=s.length(),sum=0;
for(int i=0;i<len;++i) {
if(s[i]=='A') {
int num1,num2;
num1=num2=0;
for(int j=0;j<i;++j) if(s[j]=='Q') num1++;
for(int j=i+1;j<len;++j) if(s[j]=='Q') num2++;
if(num1&&num2) sum+=num1*num2;
}
}
cout<<sum<<endl;
return 0;
}

B. Ralph And His Magic Field

  • 题目大意:给一个\(n*m\)的格子,使得每一行与每一列都等于给定的k值,k取1或者-1
  • 我比较笨,没做出来,下来之后补题用达标发现规律
  • 最后的方案数为\(res = 2 ^{(n-1)*(m-1)}\)当\(n,m\)一个是奇数一个是偶数,且\(k==-1\)时直接输出0即可
  • 注意先计算\(2^{(n-1)}\)再计算\((2^{(n-1)})^{m-1}\),不然直接计算会使得中途的结果就不一样
  • 最终程序:
#include <iostream>
#include <stdio.h>
using namespace std;
typedef long long ll;
const ll mod = 1000000007;
ll n,m,k;
ll qpow(ll base, ll num) {
ll res=1;
while(num) {
if(num&1) res=((res%mod)*(base%mod))%mod;
num>>=1;
base=((base%mod)*(base%mod))%mod;
}
return res;
}
int main() {
scanf("%I64d %I64d %I64d",&n,&m,&k);
if(((n&1)!=(m&1))&&k==-1) {
printf("0\n");
return 0;
}
printf("%I64d\n", qpow(qpow(2,n-1),m-1));
return 0;
}
  • 打表程序
#include <iostream>
using namespace std;
int a[14][14];
int b[2]={-1,1};
int n,m,num,sum=0;
bool check() {
int temp;
for(int i=1; i<=n; ++i) {
temp=1;
for(int j=1; j<=m; ++j) {
temp*=a[i][j];
}
if(temp!=num) return false;
}
for(int i=1; i<=m; ++i) {
temp=1;
for(int j=1; j<=n; ++j) {
temp*=a[j][i];
}
if(temp!=num) return false;
}
return true;
}
void dfs(int x, int y) {
for(int i=0; i<=1; ++i) {
a[x][y]=b[i];
if(x<n&&y<m) dfs(x,y+1);
else if(x<n&&y==m) dfs(x+1,1);
else if(x==n&&y<m) dfs(x,y+1);
else if(x==n&&y==m) {
if(check()) sum++;
}
}
}
int main() {
while(cin>>n>>m>>num) {
sum=0;
dfs(1,1);
cout<<sum<<endl;
}
return 0;
}

C. Marco and GCD Sequence

  • 题目大意:给定已经求出的区间gcd,看是否存在序列满足求出的gcd
  • 思路:因为给定了gcd,那么可使最小的数要成为其他区间的gcd(插
  • 入),这是一定满足要求的解法。如果其他数不能被最小数整除,这
  • 说明给定gcd缺少了元素。
  • eg_1: 2 3 6 10
  • 其中3不能被2整除,说明给定gcd缺少了元素,添加1:1 2 3 6 10才可以
  • answer:1 (1) 2 (1) 3 (1) 6 (1) 10 gcd(ai,aj)=1;
  • eg_2:1 3 5 6 10 15 把最小数插入中间即可满足
  • answer:1 (1) 3 (1) 5 (1) 6 (1) 10 (1) 15 gcd(ai,aj)=1;
#include <iostream>
using namespace std;
int main() {
int n,ans[1005];
cin>>n;
for(int i=1;i<=n;++i) cin>>ans[i];
for(int i=1;i<=n;++i) {
if(ans[i]%ans[1]) {
cout<<"-1"<<endl;
return 0;
}
}
cout<<n+(n-1)<<endl;
for(int i=1;i<n;++i) cout<<ans[i]<<" "<<ans[1]<<" ";
cout<<ans[n]<<endl;
return 0;
}

codeforces #447 894A QAQ 894B Ralph And His Magic Field 894C Marco and GCD Sequence的更多相关文章

  1. Codeforces 894B - Ralph And His Magic Field

    894B - Ralph And His Magic Field 思路: 当k为1时,如果n和m奇偶性不同,那么没有答案. 可以证明,在其他情况下有答案,且答案为2^(n-1)*(m-1),因为前n- ...

  2. codeforces 894B - Ralph And His Magic Field - [数学题]

    题目链接:https://cn.vjudge.net/problem/CodeForces-894B Ralph has a magic field which is divided into n × ...

  3. Codeforces Round #447 (Div. 2) B. Ralph And His Magic Field【数论/组合数学】

    B. Ralph And His Magic Field time limit per test 1 second memory limit per test 256 megabytes input ...

  4. Codeforces Round #447 (Div. 2) B. Ralph And His Magic Field 数学

    题目链接 题意:给你三个数n,m,k;让你构造出一个nm的矩阵,矩阵元素只有两个值(1,-1),且满足每行每列的乘积为k,问你多少个矩阵. 解法:首先,如果n,m奇偶不同,且k=-1时,必然无解: 设 ...

  5. codeforces 894C - Marco and GCD Sequence - [有关gcd数学题]

    题目链接:https://cn.vjudge.net/problem/CodeForces-894C In a dream Marco met an elderly man with a pair o ...

  6. Codeforces 894.B Ralph And His Magic Field

    B. Ralph And His Magic Field time limit per test 1 second memory limit per test 256 megabytes input ...

  7. 【Codeforces Round #447 (Div. 2) B】Ralph And His Magic Field

    | [链接] 我是链接,点我呀:) [题意] 给你一个n*m矩阵,让你在里面填数字. 使得每一行的数字的乘积都为k; 且每一列的数字的乘积都为k; k只能为1或-1 [题解] 显然每个位置只能填1或- ...

  8. Codeforces Round #447 (Div. 2) C. Marco and GCD Sequence【构造/GCD】

    C. Marco and GCD Sequence time limit per test 1 second memory limit per test 256 megabytes input sta ...

  9. 【Codeforces Round #447 (Div. 2) C】Marco and GCD Sequence

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 把gcd(a[1..n])放在输入的n个数之间. [代码] /* 1.Shoud it use long long ? 2.Have ...

随机推荐

  1. java中matches的用法

    在java中,时常会用到查看一个字符串是否是数字,这时就可以用到matches()函数. 具体实例如下: public boolean string_matches(String amatch) { ...

  2. .13-Vue源码之patch(3)(终于完事)

    怎么感觉遥遥无期了呀~这个源码,跑不完了. 这个系列写的不好,仅作为一个记录,善始善终,反正也没人看,写着玩吧! 接着上一节的cbs,这个对象在初始化应该只会调用create模块数组方法,简单回顾一下 ...

  3. 网络基础三 ARP 地址分类 NAT技术

    第1章 OSI回顾 1.1 TCP/IP协议族组成 应用层 主机到主机层   互联网层   网络接入层 1.2 总结应用层掌握的协议与端口号对应关系 http(80) telnet(23) ftp(2 ...

  4. HQL语法

    HQL:Hibernate Query Language HQL是完全面向对象的查询语言,因此可以支持继承和多态等特征. $下面介绍HQL语句的语法 1.from子句 from Person 表明从P ...

  5. web前端优化--DOM性能优化

    1.DOM访问与修改的优化: DOM访问是有代价的,修改DOM则会引起DOM的重绘与重排,而这两种操作会消耗性能. (1)缓存DOM:将频繁访问的对象或属性使用变量缓存起来,每次访问的时候,直接使用变 ...

  6. 获取 修改 CSS 样式

    内联(style里的)样式 element.style.color element.style.getPropertyValue("color")   非内联样式 window.g ...

  7. 自建梯子教程:vultr+ssr+SwitchyOmega

    1 综述 在饱受蓝灯挂掉之苦半个月后,终于决定自己搭建VPS服务器FQ了.虽然网上VPS服务器教程很多,但是我按照那些教程弄好VPS服务器总是不稳定,用着用着就不能用了.这应该是这次GFW升级带来的后 ...

  8. css 选择器和优先级

    css样式是做网页时,页面 布局不可或缺的关键点.但是在做网页时,会遇到一些明明已经设置了样式的元素,缺无法达到想要的效果,这种情况比较常见.这就涉及到优先级的问题了 要说到css的优先级,先来看下c ...

  9. Maven中settings.xml的配置项说明精讲

    1.Maven的配置文件(Maven的安装目录/conf/settings.xml ) 和 Maven仓库下(默认的Maven仓库的是用户家目录下的.m2文件,可以另行制定)的settings.xml ...

  10. DIY 温控烙铁

    由于工艺原因,某处要使用200W大功率烙铁(恒温烙铁虽然有那么大功率,但没有那么大的烙铁头),只能选用普通电热丝烙铁(无温控),存在温度过高现象(造成工艺不良,同时因助焊剂+高温造成烙铁头腐蚀),逐渐 ...