鱼C论坛

 找回密码
 立即注册
查看: 1101|回复: 4

[已解决]在长度为n的线性表A的第i个位置插入一个新数据元素item

[复制链接]
发表于 2018-10-31 21:48:19 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
照书上的算法敲得自己写的代码。乱七八糟,感觉对某些不理解。算法不动,大家改代码。
  1. void INSERTLIST (ElemType A[],int &n,int i,ElemType item)
  2. {
  3.         int j;
  4.         if (n == MaxSize || i < 1 || i > n+1)
  5.         {
  6.                 ERRORMESSAGE ("表满或插入位置不正确!");/*插入失败*/
  7.         }
  8.         for (j = n-1;j >= i-1;j--)
  9.         {
  10.                 A[j+1] = A[j];                                                        /*数据元素依次后移一个位置*/
  11.         }
  12.         A[i-1] = item;                                                                /*将item插入表的第i个位置 */
  13.         n++;                                                                                /*表的长度加1*/
  14. <div> } </div><div>
  15. </div>
复制代码
最佳答案
2018-10-31 22:51:01

不搞数据结构啦?
  1. #include <cstdio>

  2. #define MaxSize 1000
  3. int A[100];
  4. int n;

  5. void INSERTLIST(int A[], int &n, int i,int item = 3)
  6. {
  7.     if(n == MaxSize || i < 1 || i > n+1)
  8.     {
  9.         printf ("±í&#194;ú&#187;ò2&#229;è&#235;&#206;&#187;&#214;&#195;2&#187;&#213;yè·£&#161;");/*2&#229;è&#235;꧰ü*/
  10.         return;
  11.     }
  12.     int j;
  13.     n++;                                        /*±íμ&#196;3¤&#182;è&#188;ó1*/
  14.     for(j = n-1; j > i; j--)
  15.     {
  16.         A[j] = A[j-1];                                                        /*êy&#190;Y&#212;a&#203;&#216;òà′&#206;oóò&#198;ò&#187;&#184;&#246;&#206;&#187;&#214;&#195;*/
  17.     }
  18.     A[i] = item;                /*&#189;&#171;item2&#229;è&#235;±íμ&#196;μúi&#184;&#246;&#206;&#187;&#214;&#195; */
  19.    
  20. }

  21. int main()
  22. {
  23.     int a[100] = {10,20,30,40};
  24.     n = 4;
  25.     INSERTLIST (a,n,2,5);
  26.     for (int i = 0; i < n; i++)
  27.     {
  28.         printf("%d ",a[i]);
  29.     }
  30.    
  31.     return 0;
  32. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2018-10-31 21:48:58 | 显示全部楼层
  1. #define MaxSize 1000
  2. int A[100];
  3. int n;
  4. void INSERTLIST (int A[],int &n,int i,int item = 3)
  5. {
  6.         int j;
  7.         if (n == MaxSize || i < 1 || i > n+1)
  8.         {
  9.                 printf ("表满或插入位置不正确!");/*插入失败*/
  10.         }
  11.         for (j = n-1;j >= i-1;j--)
  12.         {
  13.                 A[j+1] = A[j];                                                        /*数据元素依次后移一个位置*/
  14.         }
  15.         A[i-1] = item;                                                                /*将item插入表的第i个位置 */
  16.         n++;                                                                                /*表的长度加1*/
  17. }
  18. int main()
  19. {
  20.         int a[100] = {10,20,30,40};
  21.         INSERRTLIST (a,100,2,3);
  22.         for (i = 1;i<5;i++)
  23.         {
  24.                 printf("%d",a[i]);
  25.          }
  26. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-10-31 22:51:01 | 显示全部楼层    本楼为最佳答案   

不搞数据结构啦?
  1. #include <cstdio>

  2. #define MaxSize 1000
  3. int A[100];
  4. int n;

  5. void INSERTLIST(int A[], int &n, int i,int item = 3)
  6. {
  7.     if(n == MaxSize || i < 1 || i > n+1)
  8.     {
  9.         printf ("±í&#194;ú&#187;ò2&#229;è&#235;&#206;&#187;&#214;&#195;2&#187;&#213;yè·£&#161;");/*2&#229;è&#235;꧰ü*/
  10.         return;
  11.     }
  12.     int j;
  13.     n++;                                        /*±íμ&#196;3¤&#182;è&#188;ó1*/
  14.     for(j = n-1; j > i; j--)
  15.     {
  16.         A[j] = A[j-1];                                                        /*êy&#190;Y&#212;a&#203;&#216;òà′&#206;oóò&#198;ò&#187;&#184;&#246;&#206;&#187;&#214;&#195;*/
  17.     }
  18.     A[i] = item;                /*&#189;&#171;item2&#229;è&#235;±íμ&#196;μúi&#184;&#246;&#206;&#187;&#214;&#195; */
  19.    
  20. }

  21. int main()
  22. {
  23.     int a[100] = {10,20,30,40};
  24.     n = 4;
  25.     INSERTLIST (a,n,2,5);
  26.     for (int i = 0; i < n; i++)
  27.     {
  28.         printf("%d ",a[i]);
  29.     }
  30.    
  31.     return 0;
  32. }
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-11-1 06:22:14 | 显示全部楼层
claws0n 发表于 2018-10-31 22:51
不搞数据结构啦?

书上的数据结构函数里面的都理解,但是函数的形参好多都不理解,所以写个程序,搞懂了,就知道它的意思了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-11-1 07:14:43 From FishC Mobile | 显示全部楼层
大可爱 发表于 2018-11-1 06:22
书上的数据结构函数里面的都理解,但是函数的形参好多都不理解,所以写个程序,搞懂了,就知道它的意思了

参数的名字不好??
普遍上 n 是数组长度,i 位置,item 新的元素。
后面的元素先往后挪,插入新元素,就这样。
不知怎么乱码了,不好意思~
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-26 21:22

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表