9-18 fruit.c

 #include <stdio.h>
 #define MAXN 10000
 int Queue1[MAXN], Queue2[MAXN];
 void Insert(int n, int data)    //按增序插入数组
 {
    int i, mid, left, right;
    left = ;
    right = n - ;
     || data >= Queue1[right])    //最大
    {
       Queue1[n] = data;
       return;
    }
    else if (data < Queue1[left])    //最小
    {
       ; i--)
       {
          Queue1[i + ] = Queue1[i];
       }
       Queue1[] = data;
       return;
    }
    while (left <= right)
    {
       mid = (left + right) / ;
       if (Queue1[mid] <= data)
       {
          left = mid + ;
       } else if (Queue1[mid] > data)
       {
          right = mid - ;
       }
    }
    if (Queue1[mid] < data)
       mid++;
    ; i >= mid; i--)    //插入到a[mid]之前
    {
       Queue1[i + ] = Queue1[i];
    }
    Queue1[mid] = data;
 }
 int Calc(int a[], int n)    //按增序插入数组
 {
    int i, frontOld, frontNew, rearNew;
    ;
    )
       ];
    )
       ] + a[];
    ; i < n; i++)    //按增序插入数组
       Insert(i, a[i]);
    //先加上前两个
    frontOld = frontNew = rearNew = ;
    Queue2[rearNew++] = Queue1[frontOld] + Queue1[frontOld + ];
    frontOld += ;
    while (frontOld < n)    //合并Queue1的所有元素
    {
       if (Queue1[frontOld] > Queue2[frontNew])
          sum = Queue2[frontNew++];
       else
          sum = Queue1[frontOld++];

       if (frontNew < rearNew && frontOld < n)
       {
          if (Queue1[frontOld] > Queue2[frontNew])
             sum += Queue2[frontNew++];
          else
             sum += Queue1[frontOld++];
       }
       else if (frontNew < rearNew)
          sum += Queue2[frontNew++];
       else if (frontOld < n)
          sum += Queue1[frontOld++];
       Queue2[rearNew++] = sum;
    }
    )    //如果Queue2的元素没有合并完
    {
       Queue2[rearNew++] = Queue2[frontNew] + Queue2[frontNew + ];
       frontNew += ;
    }
    sum = ;
    ; i < rearNew; i++)
       sum += Queue2[i];
    return sum;
 }
 int main()
 {
    int n, i, sum;
     };
    FILE *fp1, *fp2;
    if ((fp1 = fopen("fruit.in", "r")) == NULL)
    {
       printf("不能打开文件!\n");
       exit();
    }
    fscanf(fp1, "%d\n", &n); //果子种类数
    ; i < n; i++) //各类果子的数量
       fscanf(fp1, "%d", &a[i]);
    fclose(fp1);
    sum = Calc(a, n);
    if ((fp2 = fopen("fruit.out", "w")) == NULL)
    {
       printf("不能打开文件!\n");
       exit();
    }
    printf("%d\n", sum);
    fprintf(fp1, "%d\n", sum);
    fclose(fp2);
    getch();
    ;
 }

9-19 chorus.c

 #include <stdio.h>
 #define MAXN 101
 int main()
 {
    }, flag2[MAXN]={}, a[MAXN]={};
    int n, max;
    int i, j;
    FILE *fp1, *fp2;
    if ((fp1 = fopen("chorus.in", "r")) == NULL)
    {
       printf("不能打开文件!\n");
       exit();
    }
    fscanf(fp1, "%d\n", &n);
    ; i <= n; i++)
       fscanf(fp1, "%d", &a[i]);
    fclose(fp1);
    a[] = ;    //设置为一个最小值
    ; i <= n; i++) //用动规求最长升序序列
    {
       ; j >= ; j--)
       {
           > flag1[i]))
             flag1[i] = flag1[j] + ;
       }
    }
    a[n + ] = ;    //最后设置一个最小值
    ; i--)//用动规求最长降序序列
    {
       ; j <= n + ; j++)
       {
           > flag2[i])
             flag2[i] = flag2[j] + ;
       }
    }
    max = ;
    ; i <= n; i++) //计算升序和降序序列的最多人数
    {
       if (flag1[i] + flag2[i] > max)
       {
          max = flag1[i] + flag2[i];
          printf("%d,%d\n",flag1[i],flag2[i]);
       }
    }
    if ((fp2 = fopen("chorus.out", "w")) == NULL)
    {
       printf("不能打开文件!\n");
       exit();
    }
    printf(); //减去要保留的人数,就得到出列人数
    fprintf(fp2, );
    fclose(fp2);
    getch();
    ;
 }

9.2 NOIP提高组试题精解(2)的更多相关文章

  1. 9.2 NOIP提高组试题精解(1)

    9-16 poise.c #include <stdio.h> #define MAXN 1001 int main() { ], flag[MAXN] = { }; //保存6种砝码的数 ...

  2. 9.1 NOIP普及组试题精解(2)

    9-4 soldier.c #include <stdio.h> #define MAXN 21 }; int n, m, x, y; //n,m为B点的行列坐标位置,x,y为马的坐标位置 ...

  3. 9.1 NOIP普及组试题精解(3)

    9-6 seat.c #include <stdio.h> #define MAXN 1001 void swap(int *a, int *b) //交换数据 { int t; t = ...

  4. 9.1 NOIP普及组试题精解(1)

    9-1 series1.c #include <stdio.h> int main() { float s=0.0,k; int n; printf("输入数字k(1~15):& ...

  5. noip2010初赛提高组 试题详解

    转载自:https://blog.csdn.net/eirlys_north/article/details/52889970 一.单项选择题 1.与16进制数 A1.2等值的10进制数是 ( ) A ...

  6. noip2011初赛提高组 试题详解

    转载自:https://blog.csdn.net/Eirlys_North/article/details/52889993 一.单项选择题(共20题,每题1.5分,共计30分,每题有且仅有一个正确 ...

  7. NOIP提高组2004 合并果子题解

    NOIP提高组2004 合并果子题解 描述:在一个果园里,多多已经将所有的果子打了下来,而且按果子的不同种类分成了不同的堆.多多决定把所有的果子合成一堆. 每一次合并,多多可以把两堆果子合并到一起,消 ...

  8. NOIP提高组初赛难题总结

    NOIP提高组初赛难题总结 注:笔者开始写本文章时noip初赛新题型还未公布,故会含有一些比较老的内容,敬请谅解. 约定: 若无特殊说明,本文中未知数均为整数 [表达式] 表示:在表达式成立时它的值为 ...

  9. 计蒜客 NOIP 提高组模拟竞赛第一试 补记

    计蒜客 NOIP 提高组模拟竞赛第一试 补记 A. 广场车神 题目大意: 一个\(n\times m(n,m\le2000)\)的网格,初始时位于左下角的\((1,1)\)处,终点在右上角的\((n, ...

随机推荐

  1. Spring3和Quartz2的应用实例

    /** * 任务调度类 * @author Joyce.Luo * @date 2015-3-31 下午03:32:04 * @version V3.0 * @since Tomcat6.0,Jdk1 ...

  2. Android 百度地图开发(二)

    这一篇文章主要解说的是百度地图的定位功能,然后还有MyLocationOverlay和PopupOverlay两个地图覆盖物的使用.Overlay是"图层"或"覆盖物&q ...

  3. 转:十六进制颜色与RGB颜色对照表

    http://www.vis.cc/html/ppyj/zscs/1090.html 十六进制颜色查询 颜 色 英文代码 形象描述 十六进制 RGB LightPink 浅粉红 #FFB6C1 255 ...

  4. Android---61---TabHost简单使用

    与TabHost结合使用的组件: TabWidget:代表选项卡的标签条 TabSpec:代表选项卡的一个Tab页面 TabHost不过一个简单的容器,它提供两个方法来创建.加入选项卡 newTabS ...

  5. STL源代码剖析 容器 stl_vector.h

    本文为senlie原创.转载请保留此地址:http://blog.csdn.net/zhengsenlie vector --------------------------------------- ...

  6. sprint3 【每日scrum】 TD助手站立会议第五天

    站立会议 组员 昨天 今天 困难 签到 刘铸辉 (组长) 通过网上的介绍懂得了闹钟的添加和工作原理,然后加入了震动效果 在添加日程类型处添加了选择闹钟间隔多长时间相应,并写了闹钟运行的类 广播协议也弄 ...

  7. uva 12083 Guardian of Decency (二分图匹配)

    uva 12083 Guardian of Decency Description Frank N. Stein is a very conservative high-school teacher. ...

  8. 做一个合格的程序员之浅析Spring AOP源代码(十八) Spring AOP开发大作战源代码解析

    事实上上一篇文章价值非常小,也有反复造轮子的嫌疑,网上AOP的实例非常多,不胜枚举,事实上我要说的并非这个,我想要说的就是上一节中spring的配置文件: 我们这边并没实用到我们上几节分析的哪几个AO ...

  9. sizeof运用

    解析:ss1是一个字符指针,指针的大小是一个定值,就是4字节,所以sizeof(ss1)是4字节.ss2是一个字符数组,这个数组最初未定大小,由具体填充值来定.填充值是“0123456789”.1个字 ...

  10. iOS文档预览功能教程

     本文转载至 http://blog.csdn.net/devday/article/details/6580444   文档iosuinavigationcontrollerextensionmic ...