阿里算法内推笔试题

阿里算法内推笔试题#include#include#include#include#include#include#include#include#definepi3.1415926#defineNUM10000usingnamespace

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

#include <iostream>
#include <vector>
#include <numeric>
#include<limits>
#include <cstdio>
#include <math.h>
#include <time.h>
#include <cstdlib>
#define pi 3.1415926
#define NUM 10000
using namespace std;

/** 请完成下面这个函数,实现题目要求的功能 **/
 /** 当然,你也可以不按照这个模板来作答,完全按照自己的想法来 ^-^ **/
double cal(double x,double mul,double sigma)          //计算概率密度函数
{
    double t=sqrt(2*pi);
    double t1=-(x-mul)*(x-mul)/(2*sigma*sigma);
    double f=t*exp(t1);
    return f;
}
bool inside(double x,double y)                   //判断是否在内部
{
    double a=(x*x+y*y-1)*(x*x+y*y-1)*(x*x+y*y-1)-x*x*y*y*y;
    if(a<=0)
        return true;
    else
        return false;
}

double randgass(double minvalue, double maxvalue,double miu, double sigma){
  
  //生成正态随机数
    double x,y,dscope;
    do{
        x=minvalue+(maxvalue-minvalue)*rand()/(RAND_MAX+1.0);
        y=cal(miu,miu,sigma);
        dscope=y*rand()/(RAND_MAX+1.0);
    }while(y<dscope);
    return x;
}

double leartCurve(double mu1, double sigma1, double mu2, double sigma2) {
    double xrange=mu1-3*sigma1;
    double xsplit=6*sigma1;
    double yrange=mu2-3*sigma2;
    double ysplit=6*sigma2;
    double res=0;
    double xp=0,yp=0;
    int num=0;
    srand((unsigned)time(NULL));
    for(int i=0;i<NUM;i++)
    {
        xp=randgass(xrange,xrange+xsplit,mu1,sigma1);
        yp=randgass(yrange,yrange+ysplit,mu2,sigma2);
        if (inside(xp,yp)) num++;
    }
    res=(double)num/NUM;
    return res;
}

int main() {
    double res;

    double _mu1;
    cin >> _mu1;
    //cin.ignore (std::numeric_limits<std::streamsize>::max(), '\n');

    double _sigma1;
    cin >> _sigma1;
    //cin.ignore (std::numeric_limits<std::streamsize>::max(), '\n');

    double _mu2;
    cin >> _mu2;
    //cin.ignore (std::numeric_limits<std::streamsize>::max(), '\n');

    double _sigma2;
    cin >> _sigma2;
    //cin.ignore (std::numeric_limits<std::streamsize>::max(), '\n');


    res = leartCurve(_mu1, _sigma1, _mu2, _sigma2);
    cout << res << endl;

    return 0;

}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/195707.html原文链接:https://javaforall.net

(0)
上一篇 2025年10月11日 下午11:22
下一篇 2025年10月12日 上午7:01


相关推荐

  • Opacity属性「建议收藏」

    Opacity属性「建议收藏」开发工具与关键技术:DW,CSS3作者:李敏华撰写时间:2019-2-8CSS3的简单动画,用opacity属性使图片达到一个渐透明的效果,首先建立一个div,类名随意;接下来这些就是css的一些样式设置,见截图:CSS3的一些设置接下来就是效果图效果图如下:…

    2022年5月9日
    35
  • Jmeter聚合报告参数分析

    Jmeter聚合报告参数分析如下 Label 每个请求的名称 比如 HTTP 请求等 Samples 发给服务器的请求数量 如图是 200 个请求 若模拟 100 个用户 循环 10 次 请求数是 1000 Average 单个请求的平均响应时间 默认是单个 Request 的平均响应时间 当使用了 TransactionC 时 也可以以 Transaction 为单位显示平均响应时间 Median 中位数 也

    2026年3月20日
    2
  • MATLAB插值函数interp1

    MATLAB插值函数interp1插值法    插值法又称“内插法”,是利用函数f(x)在某区间中已知的若干点的函数值,作出适当的特定函数,在区间的其他点上用这特定函数的值作为函数f(x)的近似值,这种方法称为插值法。如果这特定函数是多项式,就称它为插值多项式。线性插值法    线性插值法是指使用连接两个已知量的直线来确定在这两个已知量之间的一个未知量的值的方法。    

    2022年6月13日
    121
  • 电脑爱好者——投稿与稿费指南

    电脑爱好者——投稿与稿费指南一、稿件投到哪里?请参照期刊最近一期中各栏目每页页眉上的投稿信箱或责编信箱。投稿信箱依此为准,杂志上的责编信箱是法定的投稿信箱,稿件一定要根据内容,投对栏目。二、投稿格式如何?正文用TXT格式,若有图片须标明图号。图片直接抓为无损的BMP格式或高画质JPG格式并打包压缩为ZIP作为附件发送。无论新老作者,稿件正文末尾均要注明作者详细联系信息和通讯地址。三、稿费标准如何?稿费一般

    2022年6月12日
    57
  • PyCharm for Anaconda

    PyCharm for AnacondaPyCharmforAnaconda新版本的特点智能Python帮助 PyCharm提供了智能代码完成、代码检查、动态错误突出显示和快速修复,以及自动化的代码重构和丰富的导航功能。 Web开发框架 PyCharm为现代web开发框架(如Django、Flask、Google应用程序引擎、Pyramid和web2py)提供了强大的特定于框架的支持。 科学工具(新版本的)…

    2022年8月29日
    8
  • PyCharm 查找文件名

    PyCharm 查找文件名PyCharm 快捷键 ctrl shift n

    2026年3月20日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号