• 随机生成指定长度字符字符串(C语言实现)


    相关函数 
    srand(), rand()
    头文件
    #include<stdlib.h>

    定义函数 
    int rand(void)

    函数说明 
    rand()会返回一随机数值,范围在0至RAND_MAX 间。在调用此函数产生随机数前,必须先利用srand()设好随机数种子,如果未设随机数种子,rand()在调用时会自动设随机数种子为1。关于随机数种子请参考srand()。

    返回值 
    返回0至RAND_MAX之间的随机数值,RAND_MAX定义在stdlib.h,其值为2147483647。

    定义函数 
    void srand (unsigned int seed);

    函数说明 
    srand()用来设置rand()产生随机数时的随机数种子。参数seed必须是个整数,通常可以利用geypid()或time(0)的返回值来当做seed。如果每次seed都设相同值,rand()所产生的随机数值每次就会一样。
    随机生成指定长度字符字符串(C语言实现)
    #include <stdio.h>
    #include <stdlib.h>
    #include <string.h>
    #include <ctype.h>
    #include <time.h>
    void get_rand_str(char s[],int num)
    //如果是在一个程序的循环中不断调用这个函数,那么是没有效果的
    //虽然也是使用的系统的时间函数来初始化随机数发生器,但程序的
    //执行速度太快了,可能执行1000次循环返回的秒数都是一样的
    //time返回时间戳
    {
     //定义随机生成字符串表
     char *str = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz,./;"'<>?";
     int i,lstr;
     char ss[2] = {0};
     lstr = strlen(str);//计算字符串长度
     srand((unsigned int)time((time_t *)NULL));//使用系统时间来初始化随机数发生器
     for(i = 1; i <= num; i++){//按指定大小返回相应的字符串
      sprintf(ss,"%c",str[(rand()%lstr)]);//rand()%lstr 可随机返回0-71之间的整数, str[0-71]可随机得到其中的字符
      strcat(s,ss);//将随机生成的字符串连接到指定数组后面
     }
    }
    int main()
    {
     char s[1401]={0};//定义一个可接收1400个字符的字符数组
     get_rand_str(s,1400);
     printf("%s",s); //输出随机生成的字符串
     system("pause");
    }
     
    /* 产生介于1 到10 间的随机数值*/
    #include<stdlib.h>
    main()
    {
    int i,j;
    for(i=0;i<10;i++)
    {
    j=1+(int)(10.0*rand()/(RAND_MAX+1.0));
    printf("%d ",j);
    }
    }

    执行 
    9 4 8 8 10 2 4 8 3 6
    9 4 8 8 10 2 4 8 3 6
     
    /* 产生介于1 到10 间的随机数值,此范例与执行结果可与rand()参照*/
    #include<time.h>
    #include<stdlib.h>
    main()
    {
    int i,j;
    srand((int)time(0));
    for(i=0;i<10;i++)
    {
    j=1+(int)(10.0*rand()/(RAND_MAX+1.0));
    printf(" %d ",j);
    }
    }
    执行 
    5 8 8 8 10 2 10 8 9 9
    2 9 7 4 10 3 2 10 8 7
  • 相关阅读:
    PAT 1037. 在霍格沃茨找零钱(20)
    PAT 1036. 跟奥巴马一起编程(15)
    Topcoder SRM633 DIV2 解题报告
    HDU 4565 So Easy! 矩阵快速幂 + 共轭数
    HDU 2256 Problem of Precision 矩阵快速幂 + 共轭数
    FZU 1683 纪念SlingShot 矩阵快速幂
    CodeForces 185A Plant 矩阵快速幂
    HDU 2604 Queuing 矩阵快速幂
    HDU 1575 Tr A 矩阵快速幂
    HDU 1757 A Simple Math Problem 矩阵快速幂
  • 原文地址:https://www.cnblogs.com/xzzzh/p/6676666.html
Copyright © 2020-2023  润新知