[刷题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 ...
随机推荐
- 无线端不响应键盘事件(keydown,keypress,keyup)
今天在项目时,在android手机上使用输入法的智能推荐的词的话,不会触发keyup事件,一开始想到在focus时使用一个定时器,每隔100ms检测输入框的值是否发生了改变,如果改变了就作对应的处理, ...
- shell 中grep命令详解
用‘grep’搜索文本文件如果您要在几个文本文件中查找一字符串,可以使用‘grep’命令.‘grep’在文本中搜索指定的字符串.举个例子:假设您正在‘/usr/src/linux/Documentat ...
- mysql互为主从复制配置笔记
MySQL-master1:192.168.72.128 MySQL-master2:192.168.72.129 OS版本:CentOS 5.4MySQL版本:5.5.9(主从复制的master和s ...
- 【转】Linux 之 /etc/profile、~/.bash_profile 等几个文件的执行过程
原文网址:http://blog.csdn.net/ithomer/article/details/6322892 在登录Linux时要执行文件的过程如下:在刚登录Linux时,首先启动 /etc/p ...
- store / cache 系列
### golang go-cache An in-memory key:value store/cache (similar to Memcached) library for Go, suitab ...
- HDU 5389 Zero Escape
题意:有一些人,每人拿一个号码,有两个门,门的值分别为A和B,要求把人分成两堆(可以为空)一堆人手持号码之和的数字根若等于A或者B就可以进入A门或者B门,要求两堆人分别进入不同的门,求有几种分配方式, ...
- webservice-WebService试题
ylbtech-doc:webservice-WebService试题 WebService试题 1.A,返回顶部 001.{WebService题目}下列是Web服务体系结构中的角色的是()(选择3 ...
- webdriver(python)学习笔记六——操作测试对象
定位到具体对象后,就需要对其进行操作,比如点击.输入内容等. 一般来说,webdriver中比较常用的操作对象的方法有下面几个 click 点击对象 send_keys 在对象上模拟按键输入 clea ...
- 【LeetCode 160】Intersection of Two Linked Lists
Write a program to find the node at which the intersection of two singly linked lists begins. For ex ...
- Android FragmentActivity+viewpager的使用
使用场景,打算设计一个“底部菜单栏+其余可滑动的页面”的简单的功能. package com.lanyuweng.mibaby; import android.content.Intent; impo ...