C程序 生成随机数并存入.txt文件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C程序 生成随机数并存入.txt文件相关的知识,希望对你有一定的参考价值。

能在Dev-Cpp上运行

1、随机数大小范围是1~2的i次方,i是整数(考虑到电脑是32位的,所以i不会大于32)
2、随机数个数是M
3、得到的随机数存入命名为test_i_M.txt文件(如输入i=20,M=1000,则test_20_1000.txt)
4、随机数不重复,且递增排列,数与数之间用空格隔开
5、.txt文件中第一行显示.i i的大小,第二行显示.M M的大小,第三行开始显示随机数(从小到大)
6、每条语句都有注释

答得好在加分

你好,我是大鱼儿不吐泡泡,用百度网盘分享给你,点开就可以保存,链接永久有效^_^链接: https://pan.baidu.com/s/1nehLdrTIqsajyoXdFkmWYQ

 提取码: jbuj 复制这段内容后打开百度网盘手机App,操作更方便哦 

--来自百度网盘超级会员v3的分享

如果有另外想要的资源或者链接失效,可以使用百度网盘推出的【收集文件】功能进行提问收集资源哦,无需转存简单快捷,功能链接:https://pan.baidu.com/disk/main#/transfer/list 微信小程序、百度网盘app、web端都已上线

参考技术A //#include "stdafx.h"//vc++6.0加上这一行.
#include "stdio.h"
#include "string.h"
#include "time.h"
#include "stdlib.h"
void main(void)
FILE *fp;//声明文件指针.
char fname[30]="test_";//文件名字符串.
int i,M,x,y,k,*p,*ptmp;
printf("Type i(1<i<32) & m(1<<i >= M)...\n");
while(1)//2^i应大于等于M,否则无法工作.
scanf("%d%d",&i,&M);
if(1<<i >= M) break;
printf("Error! redo...\n");

p=(int *)malloc(sizeof(int)*M);//根据需求大小申请空间.
ptmp=(int *)malloc(sizeof(int)*(y=1<<i));//这个空间用于实现不重复.
if(p==NULL || ptmp==NULL)//若申请空间失败则返回系统.
printf("Application memory failure...\n");
exit(0);

srand((unsigned)time(NULL));//初始化随机发生器.
for(x=0;x<y;ptmp[x]=1+x++);//初始化随机空间.
for(x=0;x<M;x++,y--)//产生M个范围在1~2^i之间的不重复随机数存于p空间.
p[x]=ptmp[k=rand()%y];
ptmp[k]=ptmp[y-1];

strcat(strcat(fname,itoa(i,(char *)ptmp,10)),"_");//生成文件名.
strcat(strcat(fname,itoa(M,(char *)ptmp,10)),".txt");
free(ptmp);//释放临时空间.
for(x=0;x<M;x++)//用选择法排序.
for(k=x,y=k+1;y<M;y++)
if(p[k]>p[y]) k=y;
if(k>x)
y=p[k];
p[k]=p[x];
p[x]=y;


if((fp=fopen(fname,"w"))==NULL)//创建文件.
printf("Create file failure...\n");
exit(0);

fprintf(fp,"%s %d\n%s %d\n",".i",i,".M",M);//写文件头.
for(x=0;x<M;fprintf(fp,"%d ",p[x++]));//将排序后的数据写入文件.
free(p);//释放工作空间.
fclose(fp);
参考技术B #include<stdio.h>
#include<stdlib.h>  //srand  rand
#include<time.h>  //time
#include<math.h> //pow
int main()

int i,M,a,s=0,j,max;
FILE *fp;
char str[]="";
scanf("%d%d",&i,&M); //输入i,M
sprintf(str,"test_%d_%d.txt",i,M); //把i,M写进文件名
fp=fopen(str,"w"); //以写方式新建一个文件
fprintf(fp,".i %d\\n.M %d\\n",i,M); //第一行显示.i i的大小,第二行显示.M M的大小
srand(time(NULL)); //初始化时间种子
max=(int)pow(2,i); //随机数的最大值
for(j=0;j<M;j++)

a=rand()%(max/M); //区间
s=s+a;   //确保随机数是从小到大
fprintf(fp,"%-5d ",s); //把随机数写进文件
if(j%10==9)fprintf(fp,"\\n");  //换行

fclose(fp); //关闭文件
return 0;

追问

很好,可是数字会重复。所以不能接受

追答现在行了,不会重复
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
#include<math.h>
int main()

int i,M,a,s=0,j,max;
FILE *fp;
char str[]="";
scanf("%d%d",&i,&M); //输入i,M
sprintf(str,"test_%d_%d.txt",i,M); //把i,M写进文件名
fp=fopen(str,"w"); //以写方式新建一个文件
fprintf(fp,".i %d\\n.M %d\\n",i,M); //第一行显示.i i的大小,第二行显示.M M的大小
srand(time(NULL)); //初始化时间种子
max=(int)pow(2,i); //随机数的最大值
for(j=0;j<M;j++)

a=rand()%(max/M)+1; //区间
s=s+a;   //确保随机数是从小到大
fprintf(fp,"%-5d ",s); //把随机数写进文件
if(j%10==9)fprintf(fp,"\\n");  //换行

fclose(fp); //关闭文件
return 0;

追问

还是不对啊。比如输入i=10;M=500;那最大是2的10次方是1024 但是结果的随机数全部都大于1024的

追答

怎么会呢?你测试过了吗?发个截图来看看

追问

追答

怎么回事?你运行我这个


参考技术C so easy.. 参考技术D 不太清楚,另请高明

python3生成随机数据,并存入sqlite3

#!/usr/bin/python
#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time    : 2018/6/15 22:46
# @Author  : Kwan
# @File    : insert_db.py
# @Software: PyCharm

import sqlite3
import random
import datetime

# conn = sqlite3.connect('local.db')
#
# c = conn.cursor()
#
# c.execute("insert into system_cfg values(?,?,?)",(2,'test2',1))
#
# conn.commit()
#
# conn.close()

def make_date():
    # def make_card_number(bits):
    #     counter = bits
        # number_list = []
        # while counter:
        #     number_list.append(str(random.randrange(0, 10)))
        #     counter -= 1
        # return number_list

    number_list = [str(x) for x in range(0, 10)]
    card_number = ''
    card_number = card_number.join(tuple(random.choices(number_list,k=10)))
    # card_number = ''
    # card_number = card_number.join(tuple(make_card_number(10)))
    car_type = random.choice(('m','p'))
    localtime = datetime.date.isoformat(datetime.datetime.now())
    data_title = ['card_number','car_type','localtime']
    data_dict = dict.fromkeys(data_title)
    data_dict['card_number'] = card_number
    data_dict['car_type'] = car_type
    data_dict['localtime'] = localtime

    return data_dict

def insert_data(list):
    conn = sqlite3.connect('test.db')
    c = conn.cursor()
    try:
        id = max(c.execute("select max(id) from monthly_card").fetchall())
        max_id = int(id[0])
        for data in list:
            card_number = data['card_number']
            db_car_number = c.execute("select card_number from monthly_card").fetchall()
            if card_number in db_car_number:
                break
            else:
                car_type = data['car_type']
                localtime = data['localtime']
                max_id += 1
                c.execute("insert into monthly_card values (?,?,?,?)", (max_id, card_number, car_type, localtime))

    except sqlite3.OperationalError:
        sql = '''create table if not exists monthly_card
                (id int primary key not null,
                card_number text not null,
                car_type text not null,
                valid text not null);'''
        c.execute(sql)
        id = 0
        for data in list:
            try:
                card_number = data['card_number']
                db_car_number = c.execute("select card_number from monthly_card").fetchall()
                if card_number in db_car_number:
                    break
                else:
                    car_type = data['car_type']
                    localtime = data['localtime']
                    id += 1
                    c.execute("insert into monthly_card values (?,?,?,?)", (id, card_number, car_type, localtime))

            except sqlite3.OperationalError:
                card_number = data['car_number']
                car_type = data['car_type']
                localtime = data['localtime']
                id += 1
                c.execute("insert into monthly_card values (?,?,?,?)", (id, card_number, car_type, localtime))
    # print(type(id_1))
    # id = id_1.fetchall()
    conn.commit()
    conn.close()


# def select_data():
#     conn = sqlite3.connect('test.db')
#     c = conn.cursor()
#     db_car_number = c.execute("select card_number")

# test1 = make_date()
# my_list = []
# my_list.append(test1)
# insert_data(my_list)
# print('OK')

n = 500
my_list = []
while n:
    my_list.append(make_date())
    n-=1
insert_data(my_list)
print('OK')


以上是关于C程序 生成随机数并存入.txt文件的主要内容,如果未能解决你的问题,请参考以下文章

怎么在delphi中搜索TXT格式文件并把文件名,文件大小,路径存入数据库

怎样用C语言读取txt文件中的二进制数据并转为一维数组

写入 txt 文件的数据以某种奇怪的语言出现[C]

如何在html中读取txt内容并修改后存入txt内

java 按行读取txt文件并存入数组

java 文件读写操作 生成随机数,写入txt,然后从txt中读出