标签:personal count 字符数组 代码 answer 新技术 运算 || 地址
PSP2.1 | Personal Software Process Stages | 预估耗时(分钟) | 实际耗时(分钟) |
---|---|---|---|
Planning | 计划 | 20 | |
· Estimate | · 估计这个任务需要多少时间 | 20 | |
Development | 开发 | 1200 | |
· Analysis | · 需求分析 (包括学习新技术) | 240 | |
· Design Spec | · 生成设计文档 | 60 | |
· Design Review | · 设计复审 (和同事审核设计文档) | 20 | |
· Coding Standard | · 代码规范 (为目前的开发制定合适的规范) | 20 | |
· Design | · 具体设计 | 120 | |
· Coding | · 具体编码 | 620 | |
· Code Review | · 代码复审 | 60 | |
· Test | · 测试(自我测试,修改代码,提交修改) | 60 | |
Reporting | 报告 | 100 | |
· Test Report | · 测试报告 | 60 | |
· Size Measurement | · 计算工作量 | 20 | |
· Postmortem & Process Improvement Plan | · 事后总结, 并提出过程改进计划 | 20 | |
合计 | 1840 |
void Question(int n, int r, FILE *f) {//生成随机四则运算
int i, j, k,m, x, t, l;
int flag;
int o,p,q;
int count;//操作数数
int onum;//运算符数
int y=0;
int num[9]={0};
char operate[10]={‘\0‘};//括号加三个运算符加上分数的除号,最多9个
int tag;
char c[6] = { ‘+‘,‘-‘,‘*‘,‘/‘,‘(‘,‘.‘};
FILE *Path;
Path = fopen("A.txt","a");
f = fopen("Q.txt", "a");
if (f == NULL){
printf("打开失败\n");
fclose(f);
}
if (Path == NULL){
printf("打开失败\n");
fclose(Path);
}
for (x = 0; x < n;) {
for (i = 0; i < 8; i++) {//三个运算符以下所以最多四个操作数,最多四个分数,一共八个数
num[i] = rand() % (r-1)+1;
}
for(i = 0; i < 9; i++){ //每一轮出题都清空
operate[i] = ‘\0‘;
}
l=0;
count = (rand() % 3) + 2;//操作数取2~4
flag=0;
onum=0;
tag=0;
y = 0;
while(onum - count < -1)//定义运算符
{
t = rand() % 6;
switch (c[t]) {
case ‘+‘:
if(operate[l]==‘)‘){
operate[l+1] = ‘+‘;
l+=2;
onum++;
}
else{
operate[l++] = ‘+‘;
onum++;
}
break;
case ‘-‘:
if(operate[l]==‘)‘){
operate[l+1] = ‘-‘;
l+=2;
onum++;
}
else{
operate[l++] = ‘-‘;
onum++;
}
break;
case ‘*‘:
if(operate[l]==‘)‘){
operate[l+1] = ‘*‘;
l+=2;
onum++;
}
else{
operate[l++] = ‘*‘;
onum++;
}
break;
case ‘/‘:
if(operate[l]==‘)‘){
operate[l+1] = ‘/‘;
l+=2;
onum++;
}
else{
operate[l++] = ‘/‘;
onum++;
}
break;
case ‘(‘:
if(tag==0&&onum<1&&count>2){
operate[l+2]=‘)‘;
operate[l++] = ‘(‘;
tag=1;
}
break;
case ‘.‘:
if(operate[l-1]==‘.‘){
flag=1;
continue;
}
if(operate[l+1]==‘)‘){
operate[l+2]=operate[l+1];
operate[l+1]=‘ ‘;
operate[l++] = ‘.‘;
}
else{
operate[l++]=‘.‘;
}
y++;
break;
}
}
num[count+y]=0;
answer(num,operate,o,p,q);
if(o<0)
continue;
fprintf(f, "%d、 ", x + 1);
for(j=0,m=0,k=0;j<count;){
if(operate[m]==‘(‘){
fprintf(f,"( ");
m++;
}
else if(operate[m]==‘.‘){
if(num[k] > num[k + 1] && num[k] % num[k + 1] != 0){//加测是否为假分数
fprintf(f, "%d‘%d/%d ", num[k] / num[k + 1], num[k] % num[k + 1], num[k + 1]);
k+=2;
m++;
j++;
if(operate[m]==‘+‘||operate[m]==‘-‘)
{
fprintf(f, "%c ", operate[m]);
m++;
}
else if(operate[m]==‘*‘)
{
fprintf(f, "× ");
m++;
}
else if(operate[m]==‘/‘)
{
fprintf(f, "÷ ");
m++;
}
}
else if (num[k] < num[k + 1] ) {//检测是否为真分数
fprintf(f, "%d/%d ", num[k], num[k + 1]);
k+=2;
m++;
j++;
if(operate[m]==‘+‘||operate[m]==‘-‘)
{
fprintf(f, "%c ", operate[m]);
m++;
}
else if(operate[m]==‘*‘)
{
fprintf(f, "× ");
m++;
}
else if(operate[m]==‘/‘)
{
fprintf(f, "÷ ");
m++;
}
}
else if(num[k] % num[k+1] == 0){//若出现整除,则直接输出自然数
fprintf(f, "%d ", num[k]/num[k+1]);
k+=2;
m++;
j++;
if(operate[m]==‘+‘||operate[m]==‘-‘)
{
fprintf(f, "%c ", operate[m]);
m++;
}
else if(operate[m]==‘*‘)
{
fprintf(f, "× ");
m++;
}
else if(operate[m]==‘/‘)
{
fprintf(f, "÷ ");
m++;
}
}
}
if(k<count+y)
{
fprintf(f, "%d ", num[k]);
k++;
j++;
}
if(operate[m]==‘)‘)
{
fprintf(f, ") ");
m++;
}
if(operate[m]==‘+‘||operate[m]==‘-‘)
{
fprintf(f, "%c ", operate[m]);
m++;
}
else if(operate[m]==‘*‘)
{
fprintf(f, "× ");
m++;
}
else if(operate[m]==‘/‘)
{
fprintf(f, "÷ ");
m++;
}
}
fprintf(f, "=\n");
fprintf(Path,"%d、",x+1);
if(o==0&&p>0){
fprintf(Path,"%d/%d \n",p,q);
}
else if(o>0&&p!=0){
fprintf(Path,"%d‘%d/%d \n",o,p,q);
}
else if(o>0&&p==0){
fprintf(Path,"%d \n",o);
}
else if(p==0&&o==0){
fprintf(Path,"0 \n");
}
x++;
}
fclose(f);
fclose(Path);
}
//结构体数组,用于存放操作数
struct Number{
int num;
int son;//分子
int mot;//分母
};
void answer(int b[], char c[],int &o,int &p,int &q) { //计算中缀表达式
struct Number OPS[100]; int top1 = -1; //存放数字的结构体数组
char OPF[100]; int top2 = -1; //存放运算符的栈
int i = 0, x = 0, y = 0;
// 遍历中缀表达式
while (b[x] != 0 || c[y] != ‘\0‘) {
if ((x == 0) && (y == 0) && (c[y] == ‘(‘)) {
OPF[++top2] = c[y++];
continue;
}
if (i == 1) {
if (c[y] == ‘\0‘) {
i--;
continue;//数组空了
}
// 运算符的栈为空,直接入栈
if (top2 == -1) {
OPF[++top2] = c[y++];//入栈
}
// 运算符的栈不为空,要比较和栈顶的优先级
else if (c[y] == ‘+‘ || c[y] == ‘-‘) {
while (OPF[top2] == ‘+‘ || OPF[top2] == ‘-‘ || OPF[top2] == ‘*‘ || OPF[top2] == ‘/‘ || OPF[top2] == ‘.‘) {
opr(OPS, top1, OPF, top2); //计算
}
OPF[++top2] = c[y++]; //运算完后,c[i]入栈
}
else if (c[y] == ‘*‘ || c[y] == ‘/‘) {
while (OPF[top2] == ‘*‘ || OPF[top2] == ‘/‘ || OPF[top2] == ‘.‘) {
opr(OPS, top1, OPF, top2); //计算
}
OPF[++top2] = c[y++]; //运算完后,c[i]入栈
}
else if (c[y] == ‘.‘) {
while (OPF[top2] == ‘.‘) {
opr(OPS, top1, OPF, top2); //计算
}
OPF[++top2] = c[y++]; //运算完后,c[i]入栈
}
else if (c[y] == ‘(‘) { //左括号,直接入栈
OPF[++top2] = c[y++];
}
else if (c[y] == ‘)‘) { //右括号,处理到把‘(‘抵消
while (OPF[top2] != ‘(‘) {
opr(OPS, top1, OPF, top2); //计算
}
top2--;
y++;//弹出左括号
}
if (c[y] != ‘(‘&&c[y - 1] != ‘)‘) {
i--;
}
}
else if (i == 0) {
// str[i]是数字,直接入栈
if (b[x] == 0) {
i++;
continue;
}
OPS[++top1].num = b[x++];
OPS[top1].mot = 0;
OPS[top1].son = 0;
i++;
}
}
// 遍历完成后,检查栈是否计算完
while (top2 != -1) {
opr(OPS, top1, OPF, top2); //计算
}
o=OPS[top1].num;
p=OPS[top1].son;
q=OPS[top1].mot;//返回计算结果
}
PSP2.1 | Personal Software Process Stages | 预估耗时(分钟) | 实际耗时(分钟) |
---|---|---|---|
Planning | 计划 | 20 | 15 |
· Estimate | · 估计这个任务需要多少时间 | 20 | 15 |
Development | 开发 | 1200 | 1155 |
· Analysis | · 需求分析 (包括学习新技术) | 240 | 240 |
· Design Spec | · 生成设计文档 | 60 | 30 |
· Design Review | · 设计复审 (和同事审核设计文档) | 20 | 20 |
· Coding Standard | · 代码规范 (为目前的开发制定合适的规范) | 20 | 15 |
· Design | · 具体设计 | 120 | 100 |
· Coding | · 具体编码 | 620 | 600 |
· Code Review | · 代码复审 | 60 | 30 |
· Test | · 测试(自我测试,修改代码,提交修改) | 60 | 100 |
Reporting | 报告 | 100 | 70 |
· Test Report | · 测试报告 | 60 | 40 |
· Size Measurement | · 计算工作量 | 20 | 10 |
· Postmortem & Process Improvement Plan | · 事后总结, 并提出过程改进计划 | 20 | 20 |
合计 | 1320 | 1240 |
标签:personal count 字符数组 代码 answer 新技术 运算 || 地址
原文地址:https://www.cnblogs.com/zjh233/p/12699356.html