数列极差问题(贪心) 求数据(一直Wrong)

2024-01-04 02:58

本文主要是介绍数列极差问题(贪心) 求数据(一直Wrong),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

/*日期:2011-10-21
  作者:xiaosi
  题目: 数列极差问题(贪心)
*/
#include<iostream>
#include<cstdio>
#include<stdlib.h>
#include<math.h>
using namespace std;
#define Maxint   999999
#define Minint   -1
int progression[2001];
int progression1[2001];
int cmp(const void *a,const void *b)
{
    return *(int *)a-*(int *)b;
}
int Max(int progression[],int n)
{
    int i,j,a,b,max;
    for(i=0;i<n-1;i++)//求max
    {
        a=0;b=1;
        for(j=2;j<n;j++)
        {
            if(progression[j]<progression[a]||progression[j]<progression[b])
            {
                if(progression[a]>progression[b])
                {
                    a=j;
                }
                else
                {
                    b=j;
                }
            }
        }
        max=progression[a]*progression[b]+1;
        progression[a]=max;
        progression[b]=Maxint;
    }
    return max;
}
int Min(int progression[],int n)
{
    int i,j,a,b,min;
    for(i=n-2;i>=0;i--)//求min
    {
        a=n-2;b=n-1;
        for(j=n-3;j>=0;j--)
        {
            if(progression[j]>progression[a]||progression[j]>progression[b])
            {
                if(progression[a]<progression[b])
                {
                    a=j;
                }
                else
                {
                    b=j;
                }
            }
        }
        min=progression[a]*progression[b]+1;
        progression[a]=min;
        progression[b]=Minint;
    }
    return min;
}
int main()
{
    int n;
    while(scanf("%d",&n)!=EOF)
    {
        int min,max,M,num,i,j;
        for(i=0;i<n;i++)
        {
            scanf("%d",&progression[i]);
        }
        qsort(progression,n,sizeof(progression[0]),cmp);
        for(i=0;i<n;i++)
        {
            progression1[i]=progression[i];
        }
        max=Max(progression,n);
        //min=Min(progression1,n);
        min=1;
        for(i=n-1;i>=0;i--)
        {
            min=min*progression1[i]+1;
        }
        M=max-min;
        if(M==0)
        {
            num=1;
        }
        else
        {
            num=(int)log10(M)+1;
        }
        printf("%d\n%d\n",num,M);
    }
    return 0;
}

这篇关于数列极差问题(贪心) 求数据(一直Wrong)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/567952

相关文章

Python的pip在命令行无法使用问题的解决方法

《Python的pip在命令行无法使用问题的解决方法》PIP是通用的Python包管理工具,提供了对Python包的查找、下载、安装、卸载、更新等功能,安装诸如Pygame、Pymysql等Pyt... 目录前言一. pip是什么?二. 为什么无法使用?1. 当我们在命令行输入指令并回车时,一般主要是出现以

Nginx部署React项目时重定向循环问题的解决方案

《Nginx部署React项目时重定向循环问题的解决方案》Nginx在处理React项目请求时出现重定向循环,通常是由于`try_files`配置错误或`root`路径配置不当导致的,本文给大家详细介... 目录问题原因1. try_files 配置错误2. root 路径错误解决方法1. 检查 try_f

Python解决雅努斯问题实例方案详解

《Python解决雅努斯问题实例方案详解》:本文主要介绍Python解决雅努斯问题实例方案,雅努斯问题是指AI生成的3D对象在不同视角下出现不一致性的问题,即从不同角度看物体时,物体的形状会出现不... 目录一、雅努斯简介二、雅努斯问题三、示例代码四、解决方案五、完整解决方案一、雅努斯简介雅努斯(Janu

Spring Validation中9个数据校验工具使用指南

《SpringValidation中9个数据校验工具使用指南》SpringValidation作为Spring生态系统的重要组成部分,提供了一套强大而灵活的数据校验机制,本文给大家介绍了Spring... 目录1. Bean Validation基础注解常用注解示例在控制器中应用2. 自定义约束验证器定义自

C#实现高性能Excel百万数据导出优化实战指南

《C#实现高性能Excel百万数据导出优化实战指南》在日常工作中,Excel数据导出是一个常见的需求,然而,当数据量较大时,性能和内存问题往往会成为限制导出效率的瓶颈,下面我们看看C#如何结合EPPl... 目录一、技术方案核心对比二、各方案选型建议三、性能对比数据四、核心代码实现1. MiniExcel

MySQL索引失效问题及解决方案

《MySQL索引失效问题及解决方案》:本文主要介绍MySQL索引失效问题及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql索引失效一、概要二、常见的导致MpythonySQL索引失效的原因三、如何诊断MySQL索引失效四、如何解决MySQL索引失

一文教你如何解决Python开发总是import出错的问题

《一文教你如何解决Python开发总是import出错的问题》经常朋友碰到Python开发的过程中import包报错的问题,所以本文将和大家介绍一下可编辑安装(EditableInstall)模式,可... 目录摘要1. 可编辑安装(Editable Install)模式到底在解决什么问题?2. 原理3.

SQL常用操作精华之复制表、跨库查询、删除重复数据

《SQL常用操作精华之复制表、跨库查询、删除重复数据》:本文主要介绍SQL常用操作精华之复制表、跨库查询、删除重复数据,这些SQL操作涵盖了数据库开发中最常用的技术点,包括表操作、数据查询、数据管... 目录SQL常用操作精华总结表结构与数据操作高级查询技巧SQL常用操作精华总结表结构与数据操作复制表结

Redis中的数据一致性问题以及解决方案

《Redis中的数据一致性问题以及解决方案》:本文主要介绍Redis中的数据一致性问题以及解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、Redis 数据一致性问题的产生1. 单节点环境的一致性问题2. 网络分区和宕机3. 并发写入导致的脏数据4. 持

vscode不能打开终端问题的解决办法

《vscode不能打开终端问题的解决办法》:本文主要介绍vscode不能打开终端问题的解决办法,问题的根源是Windows的安全软件限制了PowerShell的运行,而VSCode默认使用Powe... 遇到vscode不能打开终端问题,一直以为是安全软件限制问题,也没搜到解决方案,因为影响也不大,就没有管