先上代码,再按代码讲解

#include<stdio.h>
#include<string.h>
#include<stdlib.h>
#include<time.h>
#include<algorithm>
using namespace std;
struct shudui
{
    int w,e;
    bool operator > (const shudui q)const
    {
        return w>q.w;
    }
}m[105];
int main()
{
    int a,s,d;
    srand(time(NULL));
    for(int i=0;i<=15;++i)
    {
        m[i].w=rand();
        printf("%d ",m[i].w);
    }
    printf("\n");
    printf("*********************\n");
    for(int i=0;i<=14;++i)
        if(m[i]>m[i+1]) printf("YES ");
    else printf("NO ");
    printf("\n");
}

一、

rand函数功能为获取一个伪随机数(伪随机数的概念下面会有介绍)。

1、函数名:

rand();

2、声明:

int rand();

3、所在头文件:

stdlib.h

4、功能:

返回一个伪随机数。之所以说是伪随机数,是因为在没有其它操作下,每次执行同一个程序,调用rand得到的随机数序列是固定的(不是真正的“随机”)。

5、为了使rand的结果更“真”一些,也就是令其返回值更具有随机性(不确定性),C语言在stdlib.h中还提供了srand函数,通过该函数可以设置一个随机数种子,一般用当前时间的毫秒数来做参数。通过time(NULL)可以获取到当前时间的毫秒值(该函数位于time.h)中。

6、使用rand的流程可以总结为:

1 调用srand(time(NULL))设置随机数种子。

2 调用rand函数获取一个或一系列随机数。

需要注意的是,srand只需要在所有rand调用前,被调用一次即可,没必要调用多次。

8、以下是随机获取10个整型值并输出的例子,辅助理解。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
 
int main()
{
    int i;
     
    srand(time(NULL));//设置随机数种子。
     
    for(i = 0; i < 10; i ++)//运行10次。
        printf("%d\n"rand());//每次获取一个随机数并输出。
     
    return 0;
}

注意:不能使srand()中空着

二、

1、在结构体重载运算符时如果要用sort对结构体排序,就要有bool operator < (const shudui q)const{};注意这里是‘<’号,不能对’>‘号进行重载而用于sort

2、按照1的说法,排序要用到对'<'号重载,但是对'>' '!=' '==' '>=' '<='这些符号也可以进行重载

三、(说了这么多,也该讲讲结构体重载运算符的意义)

C++中,结构体是无法进行==,>,<,>=,<=,!=这些操作的,这也带来了很多不方便的地方,尤其是在使用STL容器的时候,如果我们可以往语句中传入结构体,一些事情将会变得很简单。
比如二分查找,binary_crearch只能对数组进行查找,如果是结构体数组的话,它会报错。但很可惜,实际编程中,大部分时候操作对象是结构体数组。

原文:https://blog.csdn.net/sunny1996/article/details/51242184/

四、(重载结构体的基本形式)(之下代码的省略部分全部是之前的代码)

1、结构体内定义cmp函数

bool mmp(const shudui x, const shudui y)      //其他人的博客上面写的是&x &y ,其实的一点是指针与对象,我比较倾向于使用对象

{

return x.w<y.w;

}

另一种中就是使用结构体重载‘<’

bool operator < (const shudui x)const(使用sort时必须有这个)     //这个关键字operator是重载的关键字,记着吧!

{

return w<x.w;

}

其次还可重载其他符号,虽然不能在sort中使用,但是可以用来比较结构体大小,而省略‘.’之后的内容

bool operator==(const shudui b) const         //这个const关键字的作用是:它表示这个函数不会修改该类的任何成员。                                                                                                                                //如果没有这个const,编译器不会允许这个运算符用于一个const对象,                                                                                                                                    //如果你认为operator<只是做个比较操作,不应该修改类的数据成员。                                                                                                                                      // 那就可以在函数后面加上一个const,编译器就不允许operator<修改类的数据成员,这样更可靠。
{
    return this->w == b.w;
}
bool operator!=(const shudui b) const
{
    return this->w != b.w;
}
bool operator<=(const shudui b) const
{
    return this->w <= b.w;
}
bool operator<(const shudui b) const
{
    return this->w < b.w;
}
bool operator>=(const shudui b) const
{
    return this->w >= b.w;
}
bool operator>(const shudui b) const
{
    return this->w > b.w;
}

其中this关键字相当于一个指针,所以在它用来指向结构体的元素时用的是'->'符号,this所指的对象就是你目前所用的对象

结构体重载运算符&srand&rand的更多相关文章

  1. C++ 结构体重载运算符

    听说这个东西有很多种写法什么的,来不及了(要退役了),先整一个之前用到的,可能用到的频率比较高的东西上来. struct node{ ll x,y; }; bool operator < (co ...

  2. srand() rand() time(0)

    标准库<cstdlib>(被包含于<iostream>中)提供两个帮助生成伪随机数的函数: 函数一:int rand(void):从srand (seed)中指定的seed开始 ...

  3. srand rand

    #include <stdlib.h> srand( (time(0)); rand()%100;

  4. srand rand 随机函数

    srand函数是随机数发生器的初始化函数.原型:voidsrand(unsigned int seed); srand和rand()配合使用产生伪随机数序列.rand函数在产生随机数前,需要系统提供的 ...

  5. PAT A1129 Recommendation System (25 分)——set,结构体重载小于号

    Recommendation system predicts the preference that a user would give to an item. Now you are asked t ...

  6. 水题 ZOJ 3869 Ace of Aces

    题目传送门 水题,找出出现次数最多的数字,若多个输出Nobody //#include <bits/stdc++.h> //using namespace std; #include &l ...

  7. poj 2387——单源最短路权值大于0

    因为之前做过这个题.所以这次知道这道题有重边.这次dijkstra的写法加入了优先队列的优化 优先队列 结构体从小到大顺序的两种重载运算符的方式 bool operator <(const Ti ...

  8. 最短路--dijkstra+优先队列优化模板

    不写普通模板了,还是需要优先队列优化的昂 #include<stdio.h> //基本需要的头文件 #include<string.h> #include<queue&g ...

  9. P3223 [HNOI2012]排队

    题目描述 某中学有 n 名男同学,m 名女同学和两名老师要排队参加体检.他们排成一条直线,并且任意两名女同学不能相邻,两名老师也不能相邻,那么一共有多少种排法呢?(注意:任意两个人都是不同的) 输入输 ...

随机推荐

  1. Codeforces Round #546 (Div. 2)-D - Nastya Is Buying Lunch

    这道题,神仙贪心题... 题意就是我给出数的顺序,并给出多个交换,每个只能用于相邻交换,问最后一个元素,最多能往前交换多少步. 我们考虑这样一个问题,如果一个这数和a[n]发生交换,那么这个数作为后面 ...

  2. 微信JSSDK使用步骤(用于在微信浏览器中自定义分享,分享到朋友圈,拍照,扫一扫等功能)

    一.使用JSSDK需要一个公众号(需要认证!): (1).把自己项目的服务器地址输入. (2).把MP_verify_m7Qp93BAuIGDWRVO.txt  文件下载下来,放到该服务器域名指向的根 ...

  3. mybatis 使用注解简化xml映射文件

    目录 关于mybatis注解 初次简单使用mybatis注解示例 利用注解实现指定映射 使用注解实现表间关联(1对1) 关于mybatis注解 注解在java中特别常见,mybatis中也支持注解. ...

  4. 一.从零认识XAML

    一.XMAL的简单了解 XAML读做zaml,,它是WPF中专门用于设计UI的语言,它简单易懂,结构清晰.是一种声明式语言,当你见到一个标签时,就意味着声明了一个对象:对象之间的层级关系要么是并列,要 ...

  5. 怎么使Richedit中光标始终指到最后一行的最后面?

    Richedit中数据会不断增加.要始终能看到当前的数据.该怎么做? SendMessage(Memo->Handle, WM_VSCROLL, SB_BOTTOM, 0); SendMessa ...

  6. 安装mysql8.0出现服务无法启动,服务没报告任何错误

    改为net start mysql80 参考https://blog.csdn.net/gzejia/article/details/82156994

  7. Python future使用

    Python的每个新版本都会增加一些新的功能,或者对原来的功能作一些改动.有些改动是不兼容旧版本的,也就是在当前版本运行正常的代码,到下一个版本运行就可能不正常了. 从Python 2.7到Pytho ...

  8. <Android基础>(三) UI开发 Part 3 RecyclerView

    RecyclerView 1)RecyclerView的基本用法 2)横向滚动和瀑布流滚动 3)注册点击事件 3.6 强大的滚动控件 RecyclerView ListView缺点: 1.不使用技巧优 ...

  9. golang 代码笔记

    锁 互斥锁,g0获取锁,到释放锁之间,g1去获取锁失败,阻塞,g0释放锁之后g1获取锁成功,gn阻塞. package main import ( "fmt" "sync ...

  10. apache http跳转到https代码

    <VirtualHost *:> ServerAdmin webmasterexample.com DocumentRoot "/mnt/www/" ServerNam ...