[刷题codeforces]650A.637A
| 650A |
| 637A |
点击查看原题
650A又是一个排序去重的问题,一定要注意数据范围用long long ,而且在写计算组合函数的时候注意也要用long long 虽然10^9没有超过long的范围,但是在计算n*(n-1)/2的过程中超了,所以需要用long long ,否则会出错。
#include<iostream>
#include<cmath>
#include<cstdlib>
#include<cstdio>
#include<algorithm>
using namespace std;
long n;
struct Point {
long x,y;
};
bool cmpx(const Point &p1,const Point &p2)
{
if (p1.x!=p2.x) {
return p1.x<p2.x;
}
else {
return p1.y<p2.y;
}
}
bool cmpy(const Point &p1,const Point &p2)
{
if (p1.y!=p2.y) {
return p1.y<p2.y;
}
else {
return p1.x<p2.x;
}
}
long long cn2(long long n)
{
)/;
}
Point a[];
Point ax[];
];
Point ay[];
];
Point axy[];
];
void mysortx(Point *a,Point *ax)
{
axc[]=;
;
while (p<n) {
;
axc[]++;
ax[axc[]]=a[p];
<n && a[p+].x==a[p].x) {
p++;
coup++;
}
axc[axc[]]=coup;
p++;
}
}
void mysorty(Point *a,Point *ay)
{
ayc[]=;
;
while (p<n) {
;
ayc[]++;
ay[ayc[]]=a[p];
<n && a[p+].y==a[p].y) {
p++;
coup++;
}
ayc[ayc[]]=coup;
p++;
}
}
void mysortxy(Point *a,Point *axy)
{
axyc[]=;
;
while (p<n) {
;
axyc[]++;
axy[axyc[]]=a[p];
<n && a[p+].x==a[p].x && a[p+].y==a[p].y) {
p++;
coup++;
}
axyc[axyc[]]=coup;
p++;
}
}
int main()
{
scanf("%ld",&n);
;i<n;i++) {
scanf("%ld %ld",&a[i].x,&a[i].y);
}
sort(a,a+n,cmpx);
mysortx(a,ax);
/*for (int i=1;i<=axc[0];i++) {
cout <<ax[i].x <<"," <<ax[i].y <<"|" <<axc[i]<<endl;
}*/
sort(a,a+n,cmpy);
mysorty(a,ay);
mysortxy(a,axy);
;
;i<=axc[];i++) {
ans+=cn2(axc[i]);
}
;i<=ayc[];i++) {
ans+=cn2(ayc[i]);
}
;i<=axyc[];i++) {
ans-=cn2(axyc[i]);
}
printf("%I64d\n",ans);
;
}
637A原本是想的双关键字sort,但是后来发现没有那么麻烦,直接把数据存进1000000的数组扫两遍就行了。注意细节,尤其是for循环的起始位置。
#include<stdio.h>
#include<stdlib.h>
struct point {
int o,x,y;
};
];
int main()
{
int n;
scanf("%d",&n);
int i;
;i<=;i++) {
a[i].o=i;
}
;i<=n;i++) {
int input;
scanf("%d",&input);
(a[input].x)++;
(a[input].y)=i;
}
;
].x;
;i<=;i++) {
if (a[i].x>maxn) {
maxn=a[i].x;
maxj=i;
}
}
;
;
;i<=;i++) {
if (a[i].x==maxn && a[i].y<minm) {
mini=i;
minm=a[i].y;
}
}
printf("%d\n",a[mini].o);
;
}
[刷题codeforces]650A.637A的更多相关文章
- [刷题]Codeforces 794C - Naming Company
http://codeforces.com/contest/794/problem/C Description Oleg the client and Igor the analyst are goo ...
- [刷题codeforces]651B/651A
651B Beautiful Paintings 651A Joysticks 点击可查看原题 651B是一个排序题,只不过多了一步去重然后记录个数.每次筛一层,直到全为0.从这个题里学到一个正确姿势 ...
- [刷题]Codeforces 786A - Berzerk
http://codeforces.com/problemset/problem/786/A Description Rick and Morty are playing their own vers ...
- [刷题]Codeforces 746G - New Roads
Description There are n cities in Berland, each of them has a unique id - an integer from 1 to n, th ...
- CF刷题-Codeforces Round #481-G. Petya's Exams
题目链接:https://codeforces.com/contest/978/problem/G 题目大意:n天m门考试,每门考试给定三个条件,分别为:1.可以开始复习的日期.2.考试日期.3.必须 ...
- CF刷题-Codeforces Round #481-F. Mentors
题目链接:https://codeforces.com/contest/978/problem/F 题目大意: n个程序员,k对仇家,每个程序员有一个能力值,当甲程序员的能力值绝对大于乙程序员的能力值 ...
- CF刷题-Codeforces Round #481-D. Almost Arithmetic Progression
题目链接:https://codeforces.com/contest/978/problem/D 题解: 题目的大意就是:这组序列能否组成等差数列?一旦构成等差数列,等差数列的公差必定确定,而且,对 ...
- [刷题]Codeforces 785D - Anton and School - 2
Description As you probably know, Anton goes to school. One of the school subjects that Anton studie ...
- Codeforces刷题计划
Codeforces刷题计划 已完成:-- / -- [Codeforces370E]370E - Summer Reading:构造:(给定某些数,在空白处填数,要求不下降,并且相邻差值<=1 ...
随机推荐
- poj 3260 The Fewest Coins
// 转载自http://blog.163.com/benz_/blog/static/18684203020115721917109/算法不难看出,就是一个无限背包+多重背包.问题在于背包的范围.设 ...
- Android下二维码的扫描
Android平台下 二维码的扫描一般采用: Zxing:参考地址 Zxing功能比较强大,支持条形码和二维码的扫描,用的人也比较多,但是Zxing太大,一般开发简单的app,用起来比较麻烦. 所以网 ...
- IO的阻塞、非阻塞、同步、异步
- 【LeetCode 230】Kth Smallest Element in a BST
Given a binary search tree, write a function kthSmallest to find the kth smallest element in it. Not ...
- <译>Selenium Python Bindings 1 - Installation
Installation Introduction Selenium Python bindings 提供了一个简单的API来使用Selenium WebDriver编写使用功能/验收测试.通过Sel ...
- 帮同事写了几行代码,在 安装/卸载 程序里 注册/卸载 OCX控件
写了个小控制台程序,这个程序用来注册 / 卸载OCX控件,用在Inno Setup做的安装卸载程序里. #include "stdafx.h" #include <windo ...
- qt集成到vs2010
因为要正式开始学习图形处理相关的知识了,所以要搭建开发平台.我所要用到的平台主要是vs和qt.虽然现在已经出了vs2013了,并且外观看起来特别漂亮,但是我所要用到的qt4版本中,没有对于的qtAdd ...
- 从零开始完整Electron桌面开发(1)搭建开发环境
[OTC] # 需要知识 1. 简单的html.javascript.css知识,就是web前端入门知识. 2. 简单命令行的应用,不会也没关系,照着代码敲就行. 3. 下载安装就不说了吧. 4. 本 ...
- 面向切面编程(AOP)及其作用
在OOP设计中,它导致了大量代码的重复,而不利于各个模块的重用. 1.面向切面编程(AOP) 面向切面编程(AOP)就是对软件系统不同关注点的分离,开发者通过拦截方法调用并在方法调用前后添加辅助代码. ...
- User experience
User experience 以用户为中心, --通过简单的操作快速完成美好的任务 简单 聚焦,我在干什么?我接下来要干什么? 删除.隐藏,合并.分组 使用背景色,而非边框来划分区域 碎片化,电话不 ...