zoukankan      html  css  js  c++  java
  • 不移动数组的插入法

    题目大意:

    对已经排好的顺序(由小到大),插入一个数字。输出也是由小到大。

    输入:3 3

       1 2 4

    输出:1 2 3 4

    代码如下:

    #include<iostream>
    using namespace std;
    int num[1000];
    int main()
    {
     int n, m;
     while (scanf("%d%d", &n, &m) && (n+m))
     {
      bool flag = true;
      int Inum;
      int k=0;
      for (int i = 0; i < n; i++)
      {
       cin >> num[k];
       if (num[k] >= m&&flag)
       {
        Inum = num[k];
        num[k] = m;
        k++;
        num[k] = Inum;
        flag = false;
       }
       k++;
      }
      if (flag)
      {
       num[k] = m;
      }
      for (int j = 0; j <= n; j++)
      {
       cout << num[j];
       if (j < n){ cout << " "; }
      }
      cout << endl;
     }
     return 0;
    }

     if (num[k] >= m&&flag)
       {
        Inum = num[k];
        num[k] = m;
        k++;
        num[k] = Inum;
        flag = false;
       }

    这段代码非常重要,如果num[i]比m大就将它插入;注意:如果不考虑有几个数都比m大,那么就会使得几个插入。所以我们插入一次就可以了

    用flag来判断插入一次。

  • 相关阅读:
    ftp服务器架设
    samba服务器架设
    apache安装
    yum及prm安装
    redis安装与使用
    memcached安装与使用
    mysql主从服务器
    nginx负载均衡服务器搭建
    lnmp环境搭建
    linux笔记
  • 原文地址:https://www.cnblogs.com/damaoranran/p/8654948.html
Copyright © 2011-2022 走看看