typedef long long int ll
时间: 2023-10-16 20:08:25 浏览: 286
这是一个C++中的typedef语句,将long long int类型定义为ll类型,方便在代码中使用。例如:
```
typedef long long int ll;
ll x = 123456789;
```
相当于
```
long long int x = 123456789;
```
相关问题
C语言 typedef long long int ll; ll a[(ll)(1e6+10)]; 与#define int long long int a[(int)(1e6+10)];有什么区别
C语言中,typedef long long int ll; ll a[(ll)(1e6 10)]; 的意思是定义一个名为ll的类型,它是long long int类型的别名。然后定义了一个名为a的数组,它有1e6 10个元素,其类型为ll。即a是一个有1e6 10个long long int类型元素的数组。
#include<stdio.h> #include<iostream> #include<string.h> #include<algorithm> #include<queue> #include<stack> #include<math.h> #include<map> typedef long long int ll; using namespace std; #define maxn 0x3f3f3f3f #define INF 0x3f3f3f3f3f3f3f3f const int mm=1e6+100; ll d[mm]; struct f{ ll a,b; }num[mm]; bool cmp(f k,f kk) { if(k.a!=kk.a) return k.a<kk.a;//a升序 else return k.b>kk.b;//b降序 } int main() { ll n,m,i,j,t,a,b,c,p,k,kk,l,r; scanf("%lld%lld",&n,&m); for(i=1;i<=n;i++) scanf("%lld",&d[i]); for(i=1;i<=m;i++) scanf("%lld",&num[i].a); for(i=1;i<=m;i++) scanf("%lld",&num[i].b); sort(num+1,num+1+m,cmp); for(i=1;i<=m;i++) { num[i].b=max(num[i-1].b,num[i].b); } ll sum=0; for(i=1;i<=n;i++) { l=0; r=m; p=0; while(l<=r) { ll mid=(l+r)/2; if(d[i]>num[mid].a) { p=mid; l=mid+1; } else r=mid-1; } sum+=num[p].b; } printf("%lld\n",sum); }解释这段代码
这段代码实现了一个题目的解法。具体题目不清楚,但代码中的变量名和注释可以大致理解其思路。
首先,读入一个数列 `d` 和一些二元组 `(a,b)`,并将这些二元组按照 `a` 为第一关键字升序排序,`b` 为第二关键字降序排序。然后,对于每个 `d[i]`,在排序后的二元组中二分查找第一个 `a` 大于等于 `d[i]` 的二元组,并累加其对应的 `b` 值。
具体来说,变量解释如下:
- `n`:数列 `d` 的长度。
- `m`:二元组的数量。
- `num`:存储二元组的数组。
- `d`:存储数列的数组。
- `cmp`:比较函数,按照上述方式比较两个二元组大小。
- `l`、`r`、`mid`、`p`:二分查找时使用的变量。
- `sum`:累加的结果,即所有 `d[i]` 对应的 `b` 值之和。
具体实现细节见代码注释:
阅读全文