专题I_K个人解题报告-三分

I题:HDU 3714

分析:求F(x)=max(Si(x));
画图分析易知F(x)一定是一个下凸的图像,三分
这个题的精度要注意,还不会精度到底要怎么搞,我一般都取1e-7,这次wa了,取了1e-10过了。

#include <bits/stdc++.h>
using namespace std;

//把F[x]=max(s(x))表示出来;
int n;

struct node{double a,b,c;}p[10010];
double S(double a,double b,double c,double x){return a*x*x+b*x+c;}
double F(double x){
    double m=S(p[1].a,p[1].b,p[1].c,x);
    for(int i=2;i<=n;i++){
        m=max(m, S(p[i].a,p[i].b,p[i].c,x) );
    }
    return m;
}

double Trfi(double l,double r){
    double ll=(l*2+r)/3,rr=(r*2+l)/3;
    while(rr-ll>1e-10){
        if( F(ll)>F(rr) ) l=ll;
        else r=rr;
        ll=(l*2+r)/3,rr=(r*2+l)/3;
    }
    return F((rr+ll)/2);
}

int main(){
    int t;scanf("%d",&t);
    while(t--){
        scanf("%d",&n);
        for(int i=1;i<=n;i++){
            scanf("%lf%lf%lf",&p[i].a,&p[i].b,&p[i].c);
        }
        printf("%.4f\n",Trfi(0.0,1000.0));
    }
    return 0;
}

这个题又学到了一个“代码技巧”:就是多个函数取最大值(最小值)的操作

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要制作一个Python单机考试答题系统,可以按照以下步骤进行: 1. 确定考试题目的格式和数量,可以将题目保存在一个文本文件中,每道题目包含题干、选项和答案。 2. 编写程序读取题目文件,并将每道题目的信息存储在一个数据结构中,比如列表或字典。 3. 编写程序随机选择一定数量的题目作为考试题目,并将它们显示给考生。 4. 考生选择答案,并在程序中记录答案。 5. 考试结束后,程序自动批改考试,并计算得分。 6. 显示考试结果,包括得分和答题情况。 下面是一个简单的Python单机考试答题系统的代码示例: ```python import random class Exam: def __init__(self, filename, num_questions): self.questions = self.load_questions(filename) self.num_questions = num_questions self.score = 0 self.answers = [] def load_questions(self, filename): questions = [] with open(filename, 'r') as f: lines = f.readlines() for i in range(0, len(lines), 6): question = { 'stem': lines[i].strip(), 'options': [ lines[i+1].strip(), lines[i+2].strip(), lines[i+3].strip(), lines[i+4].strip() ], 'answer': lines[i+5].strip() } questions.append(question) return questions def start(self): random.shuffle(self.questions) for i in range(self.num_questions): question = self.questions[i] print('{}. {}'.format(i+1, question['stem'])) for j, option in enumerate(question['options']): print(' {}. {}'.format(j+1, option)) answer = input('Your answer: ') self.answers.append(answer) self.grade() def grade(self): for i, question in enumerate(self.questions): if self.answers[i] == question['answer']: self.score += 1 print('Your score is {}/{}.'.format(self.score, self.num_questions)) print('Your answers: {}'.format(' '.join(self.answers))) print('Correct answers: {}'.format(' '.join([question['answer'] for question in self.questions]))) if __name__ == '__main__': exam = Exam('questions.txt', 5) exam.start() ``` 在这个示例中,题目文件的格式如下: ``` What is the capital of France? A. London B. Paris C. Berlin D. Rome B What is the largest planet in the solar system? A. Jupiter B. Mars C. Venus D. Earth A ... ``` 每道题目由题干、四个选项和答案组成,用空行隔开。程序使用load_questions方法读取题目文件,并将每道题目的信息保存在一个字典中。在start方法中,程序随机选择一定数量的题目作为考试题目,并将它们显示给考生。考生选择答案后,程序记录答案,并在grade方法中自动批改考试,计算得分。最后,程序显示考试结果,包括得分和答题情况。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值