ホームページ  >  記事  >  バックエンド開発  >  C 言語は、順序付けられた配列に数値を挿入し、順序を維持する機能を実装します。

C 言語は、順序付けられた配列に数値を挿入し、順序を維持する機能を実装します。

王林
王林オリジナル
2020-05-08 13:37:067841ブラウズ

C 言語は、順序付けられた配列に数値を挿入し、順序を維持する機能を実装します。

アルゴリズムのアイデア:

先頭からたどって要素より大きい最初の数値を見つけ、その数値を挿入すると、後続の要素が順番に移動されます。 。

サンプルコード:

#include<stdio.h>//直接插入排序
void insert_array(int *a,int length,int element)//插入函数 往有序的数组a里插入值为element的元素使数组a依然有序 
{
  int i,j,t,f;
  for(i=0;i<length;i++)
  {
    if(a[i]>element)
       {
	    t=i;//找到位置以后 可以依次移动数组元素腾出位置了
         for(j=length;j>=t;j--)
            {
               if(j==t)
                   a[j]=element;
	       else
                  a[j]=a[j-1];//数组依次往后移动 不管正序还是倒序都可以
	    }
	    f=1;
	    break;
      }
      
     
   }
   if(f!=1)//当element大于所有数组元素时候
   {
     a[length]=element;
   }
  for(i=0;i<length+1;i++)
  {
    printf("%d ",a[i]);
  } 
}
int main()
{
  int a[5]={1,2,3,5,6};
  int e=7;
  insert_array(a,5,e);
}

推奨チュートリアル:c 言語チュートリアル

以上がC 言語は、順序付けられた配列に数値を挿入し、順序を維持する機能を実装します。の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。