博客
关于我
文件四则运算
阅读量:157 次
发布时间:2019-02-28

本文共 1732 字,大约阅读时间需要 5 分钟。

四则运算:随机出十道加减乘除的题目放入文件中,并再另一个文件中解答出来

#define _CRT_SECURE_NO_WARNINGS#include
#include
#include
#include
#include
//四则运算:随机出十道加减乘除的题目放入文件中,并再另一个文件中解答出来//出题void giveQuestion(){ FILE* fp = fopen("test.txt", "w"); if (fp == NULL) { printf("文件打开失败"); return; } // int num1; int num2; char ch; //四则运算符号数组 char symbol[] = "+-*/"; //随机数种子 /*随机数种子写法: srand((unsigned int)time(NULL)); srand((size_t)time(NULL));*/ srand((size_t)time(NULL)); for (int i = 0; i < 10; i++) { //取模 100取模得的余数范围---0~99 num1 = rand() % 100 + 1 ;//范围是0+1~99+1 num2 = rand() % 100 + 1; //范围是0+1~99+1 ch = symbol[rand() % 4]; //范围是0~3 //拼接字符串放入一个新的字符串中 char buf[64] = { 0 }; sprintf(buf, "%d %c %d=\n", num1, ch, num2); //将拼接后的字符串buf放入test.txt中 fputs(buf, fp); } //关闭文件 fclose(fp); printf("十道题目生成成功!\n");}//解题void answerQuestion(){ //先将数据从文件中读取出来 FILE* fp = fopen("test.txt", "r"); if (fp == NULL) { printf("文件打开失败"); } //放入新文件中 FILE* fp1 = fopen("test1.txt", "w"); if (fp1 == NULL) { printf("文件打开失败"); } // int num1; int num2; char ch; int ret=0; //将读取的数据放入一个字符串中 while (!feof(fp)) { char buf[32] = { 0 }; char* result=fgets(buf, sizeof(buf), fp); if (result == NULL) { break; } //将每次循环读取到字符串的题目解出来 //字符串分割函数 sscanf(buf, "%d %c %d", &num1, &ch, &num2); if (ch == '+') ret = num1 + num2; if (ch == '-') //int abs 返回一个整数的绝对值 ret = num1 - num2; if (ch == '*') ret = num1 * num2; if (ch == '/') ret = num1 / num2; //将得出结果的算数式放入文件中 //1.先拼接 char buf1[32] = { 0 }; sprintf(buf1, "%d %c %d=%d\n", num1, ch, num2, ret); fputs(buf1, fp1); } fclose(fp1); fclose(fp); printf("十道题全部解出成功!\n");}int main(){ giveQuestion(); answerQuestion(); return 0;}

转载地址:http://thwc.baihongyu.com/

你可能感兴趣的文章
mysql
查看>>
MTK Android 如何获取系统权限
查看>>
MySQL - 4种基本索引、聚簇索引和非聚索引、索引失效情况、SQL 优化
查看>>
MySQL - ERROR 1406
查看>>
mysql - 视图
查看>>
MySQL - 解读MySQL事务与锁机制
查看>>
MTTR、MTBF、MTTF的大白话理解
查看>>
mt_rand
查看>>
mysql -存储过程
查看>>
mysql /*! 50100 ... */ 条件编译
查看>>
mudbox卸载/完美解决安装失败/如何彻底卸载清除干净mudbox各种残留注册表和文件的方法...
查看>>
mysql 1264_关于mysql 出现 1264 Out of range value for column 错误的解决办法
查看>>
mysql 1593_Linux高可用(HA)之MySQL主从复制中出现1593错误码的低级错误
查看>>
mysql 5.6 修改端口_mysql5.6.24怎么修改端口号
查看>>
MySQL 8.0 恢复孤立文件每表ibd文件
查看>>
MySQL 8.0开始Group by不再排序
查看>>
mysql ansi nulls_SET ANSI_NULLS ON SET QUOTED_IDENTIFIER ON 什么意思
查看>>
multi swiper bug solution
查看>>
MySQL Binlog 日志监听与 Spring 集成实战
查看>>
MySQL binlog三种模式
查看>>