排序题

题目为:

有一个已经排序的数组(升序),数组中可能有正数、负数或0,求数组中元素的绝对值最小的数,要求,不能用顺序比较的方法(复杂度需要小于O(n)),可以使用任何语言实现

例如,数组{-20,-13,-4, 6, 77,200} ,绝对值最小的是-4。

这一题该如何求呢?

初步的解决思路是:

    1.数组中的元素全为正,取最左边的数字;

    2.数组中的元素全为负,取最右边的数字的绝对值;

    3.数组中有正数有负数,就用二分法查找,判断中间元素的符号

       a)中间元素为正,继续判断中间元素前面一个元素的符号

       b)中间元素为负,判断中间元素后一个元素的符号

       c)中间元素为零,令其等于结果值返回

下面是根据上面的想法的代码实现,应该还会有漏洞

  1. #include "stdafx.h"   
  2. #include <iostream>   
  3.   
  4. using namespace std;  
  5.   
  6. //求取数组中绝对值最小的数字   
  7. int minAbsolute(int arr[],int size);  
  8. //返回两个数中较小的数   
  9. int compare(int a,int b);  
  10. int _tmain(int argc, _TCHAR* argv[])  
  11. {  
  12.     int a[10] = {-10,-8,-5,-3,2,5,8,9,11,15};     
  13.     int size = sizeof(a)/sizeof(int);  
  14.     int result = minAbsolute(a,size);  
  15.     cout<<"绝对值最小的数是:"<<result<<endl;  
  16.     return 0;  
  17. }  
  18.   
  19. int minAbsolute(int arr[],int size)  
  20. {  
  21.     int first,last,mid;   
  22.     first = 0;  
  23.     last = size - 1;  
  24.     int result;  
  25.   
  26.     //数组中的数全是负数,取最右边的数   
  27.     if (arr[0] < 0 && arr[size-1] < 0)  
  28.     {  
  29.         result = arr[size-1];  
  30.     }   
  31.     //数组中的数全是正数,取最左边的数   
  32.     else if (arr[0] > 0 && arr[size-1] > 0)  
  33.     {  
  34.         result = arr[0];  
  35.     }  
  36.     //数组有正有负,二分查找   
  37.     else  
  38.     {  
  39.         while(first < last)  
  40.         {  
  41.             int mid = (first + last)/2;  
  42.             if (arr[mid] > 0)  
  43.             {  
  44.                 if (arr[mid - 1] > 0)  
  45.                 {  
  46.                     last = mid - 1;  
  47.                 }   
  48.                 else if(arr[mid - 1] < 0)  
  49.                 {  
  50.                     result = compare(-arr[mid - 1],arr[mid]);  
  51.                     break;  
  52.                 }  
  53.                 else  
  54.                 {  
  55.                     result = arr[mid - 1];  
  56.                     break;  
  57.                 }  
  58.             }  
  59.             else if (arr[mid] < 0)  
  60.             {  
  61.                 if (arr[mid + 1] < 0)  
  62.                 {  
  63.                     first = mid + 1;  
  64.                 }   
  65.                 else if (arr[mid + 1] > 0)  
  66.                 {  
  67.                     result = compare(-arr[mid],arr[mid+1]);  
  68.                     break;  
  69.                 }   
  70.                 else  
  71.                 {  
  72.                     result = arr[mid + 1];  
  73.                     break;  
  74.                 }                 
  75.             }   
  76.             else  
  77.             {  
  78.                 result = arr[mid];  
  79.                 break;  
  80.             }  
  81.         }  
  82.     }  
  83.     return result;  
  84. }  
  85.   
  86. int compare(int a,int b)  
  87. {  
  88.     if (a > b)  
  89.     {  
  90.         return b;  
  91.     }   
  92.     else  
  93.     {  
  94.         return a;  
  95.     }  
  96. }  
内容概要:本文探讨了在MATLAB/SimuLink环境中进行三相STATCOM(静态同步补偿器)无功补偿的技术方法及其仿真过程。首先介绍了STATCOM作为无功功率补偿装置的工作原理,即通过调节交流电压的幅值和相位来实现对无功功率的有效管理。接着详细描述了在MATLAB/SimuLink平台下构建三相STATCOM仿真模型的具体步骤,包括创建新模型、添加电源和负载、搭建主电路、加入控制模块以及完成整个电路的连接。然后阐述了如何通过对STATCOM输出电压和电流的精确调控达到无功补偿的目的,并展示了具体的仿真结果分析方法,如读取仿真数据、提取关键参数、绘制无功功率变化曲线等。最后指出,这种技术可以显著提升电力系统的稳定性与电能质量,展望了STATCOM在未来的发展潜力。 适合人群:电气工程专业学生、从事电力系统相关工作的技术人员、希望深入了解无功补偿技术的研究人员。 使用场景及目标:适用于想要掌握MATLAB/SimuLink软件操作技能的人群,特别是那些专注于电力电子领域的从业者;旨在帮助他们学会建立复杂的电力系统仿真模型,以便更好地理解STATCOM的工作机制,进而优化实际项目中的无功补偿方案。 其他说明:文中提供的实例代码可以帮助读者直观地了解如何从零开始构建一个完整的三相STATCOM仿真环境,并通过图形化的方式展示无功补偿的效果,便于进一步的学习与研究。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值