博客
关于我
文件四则运算
阅读量: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 中开启二进制日志(Binlog)
查看>>
MySQL 中文问题
查看>>
MySQL 中日志的面试题总结
查看>>
mysql 中的all,5分钟了解MySQL5.7中union all用法的黑科技
查看>>
MySQL 中的外键检查设置:SET FOREIGN_KEY_CHECKS = 1
查看>>
Mysql 中的日期时间字符串查询
查看>>
mysql 中索引的问题
查看>>
MySQL 中锁的面试题总结
查看>>
MySQL 中随机抽样:order by rand limit 的替代方案
查看>>
MySQL 为什么需要两阶段提交?
查看>>
mysql 为某个字段的值加前缀、去掉前缀
查看>>
mysql 主从
查看>>
mysql 主从 lock_mysql 主从同步权限mysql 行锁的实现
查看>>
mysql 主从互备份_mysql互为主从实战设置详解及自动化备份(Centos7.2)
查看>>
mysql 主从关系切换
查看>>
MYSQL 主从同步文档的大坑
查看>>
mysql 主键重复则覆盖_数据库主键不能重复
查看>>
Mysql 事务知识点与优化建议
查看>>
Mysql 优化 or
查看>>
mysql 优化器 key_mysql – 选择*和查询优化器
查看>>