当前位置: 首页 > news >正文

做时时彩网站代理费用谷歌搜索入口手机版

做时时彩网站代理费用,谷歌搜索入口手机版,电子商务网站建设实习,wordpress 按钮支付改造序列 题目描述 给定长度为 n n n的序列 a 1 , a 2 , . . . , a n a_1,a_2,...,a_n a1​,a2​,...,an​,你可以从中删除一些数,使得删完以后的序列中,所有相邻元素之和均为偶数。请问最少需要删除多少个数? 输入格式 第一行…

改造序列

题目描述

给定长度为 n n n的序列 a 1 , a 2 , . . . , a n a_1,a_2,...,a_n a1,a2,...,an,你可以从中删除一些数,使得删完以后的序列中,所有相邻元素之和均为偶数。请问最少需要删除多少个数?

输入格式

第一行一个整数 T T T,表示测试数据组数 T T T

接下来 T T T组数据,每组数据第一行一个整数 n n n,第二行 n n n个整数,空格分开

输出格式

T T T行,每行一个整数,表示相应数据的答案

样例 #1

样例输入 #1

2
5
2 4 3 6 8
6
3 5 9 7 1 3

样例输出 #1

1
0

提示

∑ n \sum n n为一个数据点中所有 n n n之和

对于 100 % 100\% 100%的数据, 1 ⩽ T ⩽ 100 1\leqslant T\leqslant 100 1T100 3 ⩽ n ⩽ 1 0 5 3\leqslant n\leqslant 10^5 3n105 1 ⩽ a i ⩽ 1 0 9 1\leqslant a_i\leqslant 10^9 1ai109 1 ⩽ ∑ n ⩽ 1 0 5 1\leqslant \sum n\leqslant 10^5 1n105

这道题很简单,只需要判断奇数和偶数的的个数,输出最小的那个数就行了,核心代码如下:

while(t--)
{int n,ansa=0,ansb=0;	//一定要附初值,不然后面的值不对for(int i=1;i<=n;i++){cin>>a[i];if(a[i]%2==0)	//判断奇数偶数的个数{ansa++;}else{ansb++;}/*这里也个可以怎么写:int x;cin>>x;if(x%2==0){ansa++;}else{ansb++;}*/}printf("%d\n",min(ansa,ansb));
}

非倍数求和

题目描述

给定 n , a , b n,a,b n,a,b,求 1 1 1 n n n之间所有既不是 a a a的倍数也不是 b b b的倍数的数之和。

输入格式

一行,三个整数 n , a , b n,a,b n,a,b

输出格式

一行,一个整数,表示答案

样例 #1

样例输入 #1

10 3 5

样例输出 #1

22

提示

对于 30 % 30\% 30%的数据,$1\leqslant n,a,b\leqslant 10^3 $

对于 60 % 60\% 60%的数据, 1 ⩽ n , a , b ⩽ 1 0 6 1\leqslant n,a,b\leqslant 10^6 1n,a,b106

对于 100 % 100\% 100%的数据, 1 ⩽ n , a , b ⩽ 1 0 9 1\leqslant n,a,b\leqslant 10^9 1n,a,b109

这道题是一道典型的数论题,代码如下:

#include <bits/stdc++.h>
using namespace std;
long long gcd(int a,int b)
{if(b==0){return a;}return gcd(b,a%b);
}
long long lcm(int a,int b)
{return (long long)a*b/gcd(a,b);/*这道题也可以怎么写:return (long long)a*b/__gcd(a,b);这是直接调用库里的gcd手写的gcd表示:那我走*/
}
int main()
{long long n,a,b,ans=0,tota,totb,tott,t;scanf("%lld%lld%lld",&n,&a,&b);ans=(long long)(1+n)*n/2;	//高斯求和tota=(long long)(a+n/a*a)*(n/a)/2;totb=(long long)(b+n/b*b)*(n/b)/2;t=lcm(a,b);tott=(t+n/t*t)*(n/t)/2;printf("%lld",ans-tota-totb+tott);	//全部-a的倍数-b的倍数+a和b的倍数(这里因为a和b的倍数剪了两遍,所以要把那一遍加回来)return 0;
}

三数不同

题目描述

给定长度为 n n n的序列 a i a_i ai,请计算所有满足以下条件的三元组 ( i , j , k ) (i,j,k) (i,j,k)的个数

  • i < j < k i<j<k i<j<k
  • a i a_i ai a j a_j aj a k a_k ak互不相同

输入格式

第一行,一个整数 n n n

第二行 n n n个整数 a i a_i ai

输出格式

一个整数,表示答案

样例 #1

样例输入 #1

4
3 1 4 1

样例输出 #1

2

提示

对于 30 % 30\% 30%的数据, n ⩽ 2 × 100 n\leqslant 2\times 100 n2×100,$a_i\leqslant 2\times 100 $

对于 60 % 60\% 60%的数据, n ⩽ 2 × 1 0 3 n\leqslant 2\times 10^3 n2×103 a i ⩽ 2 × 1 0 3 a_i\leqslant 2\times 10^3 ai2×103

对于 100 % 100\% 100%的数据, 3 ⩽ n ⩽ 2 × 1 0 5 3\leqslant n\leqslant 2\times 10^5 3n2×105 1 ⩽ a i ⩽ 2 × 1 0 5 1\leqslant a_i\leqslant 2\times 10^5 1ai2×105

这道题是要找出有多少对 三元组 ,这道题的代码如下:

#include <bits/stdc++.h>
using namespace std;
const int N=2e6;
int h[N+10];
long long c(int n,int m)	//查找函数
{if(m==2){return (long long)n*(n-1)/2;}else if(m==3){return (long long)n*(n-1)*(n-2)/6;}
}
int main()
{int n,ans=0;scanf("%d",&n);for(int i=1;i<=n;i++){int x;scanf("%d",&x);h[x]++;}long long tot=c(n,3);	//找zzz的情况for(int i=1;i<=N;i++){if(h[i]>=2){tot-=c(h[i],2)*(n-h[i]);	//找zzy的情况,前两个找到了,最后一个随便找一个就行了}if(h[i]>=3){tot-=c(h[i],3);	//找zzz的情况}}printf("%lld",tot);return 0;
}
http://www.hkea.cn/news/962665/

相关文章:

  • 网站建设前景怎么样google优化师
  • 上海免费网站建设淘宝引流推广怎么做
  • 单位网站建设目的西安网站建设公司排行榜
  • 福州制作网站软件无人在线观看高清视频单曲直播
  • 建设银行卡网站百度账号登录个人中心
  • 网站显示500错误怎么解决方法seo网站推广排名
  • 广告免费设计在线生成网站排名优化
  • 余姚公司网站建设怎么建网址
  • 网站域名授权怎么做市场营销案例100例
  • kindeditor代码高亮 wordpressseo优化排名经验
  • 家乡介绍网页设计上海网站排名优化
  • 广州黄埔网站制作百度sem是什么意思
  • 网站流量分析网站网络推广营销网
  • 化妆品网站建设计划书网站维护是什么意思
  • 建设局网站公告宣传推广的形式有哪些
  • 网站基本架构设计的主要步骤什么软件可以排名次
  • 代做毕业设计网站多少钱网站推广交换链接
  • 苹果指争议广告lg广告北京seo公司网站
  • flash网站制作公司能打开各种网站的浏览器下载
  • 网站开发是叫系统吗站长工具seo排名查询
  • 站长之家html模板西安网站seo技术厂家
  • 重庆网站建设 渝seo交流论坛
  • 洛阳市网站建设宁波seo网络推广软件系统
  • 做网站用建站模版好还是定制好百度站点
  • 关注济南网站建设深圳市企业网站seo
  • 安溪县住房和城乡建设网站色盲
  • 合肥做英文网站今日头条国际军事新闻
  • 西安有哪些做网站的公司好邵阳疫情最新消息
  • asia域名的网站竞价广告
  • 怎么注册公司支付宝账号seo求职信息