鱼C论坛

 找回密码
 立即注册
查看: 3834|回复: 0

求高手帮助啊C语言有关动态数组的问题

[复制链接]
发表于 2012-10-23 18:05:36 | 显示全部楼层 |阅读模式

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

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

x
  1. # include <stdio.h>
  2. # include <malloc.h>
  3. # include <stdlib.h>
  4. typedef struct Arr{
  5.         char *a;
  6.         int len;
  7.         int cnt;
  8. }arr,*parr;
  9. void init_arr(parr ,int );
  10. void insert_arr(parr);
  11. void delete_arr(parr);
  12. int main ()
  13. {        arr S;
  14.         init_arr(&S,100);
  15.         insert_arr(&S);
  16.         for(int i=0;i<S.cnt;i++)
  17.         printf("%c",S.a[i]);
  18.         return 0;
  19. }
  20. void init_arr(parr pArr,int length)
  21. {        pArr->a=(char*)malloc(sizeof(char)*length);
  22. if(NULL==pArr->a)
  23. exit(-1);
  24. else{
  25. printf("请输入需要的个数:\n");
  26. scanf("%d",&pArr->cnt);
  27. printf("请输入字母\n");
  28. for(int i=0;i<pArr->cnt;i++)
  29. scanf("%s",&pArr->a[i]);
  30. }
  31. }

  32. void insert_arr(parr pArr)
  33. {       
  34.                 int pos;
  35.                 char val;
  36.         printf("请输入要插入的位置\n");
  37.                 scanf("%d",&pos);
  38.         printf("请输入要插入的元素\n");
  39.                 scanf("%s",&val);
  40.         for(int k=pArr->cnt-1;k>=pos-1;--k)
  41.         {
  42.                 pArr->a[k-1]=pArr->a[k];
  43.         }
  44.         pArr->a[pos-1] = val;
  45.         pArr->cnt++;
  46.         for(int i=0;i<pArr->cnt-1;i++)
  47.         {        int t;
  48.                 for(int j=0;j<pArr->cnt-1-i;j++)
  49.                         if(pArr->a[j]>pArr->a[j+1])
  50.                         {         t=pArr->a[j];
  51.                                 pArr->a[j]=pArr->a[j+1];
  52.                                 pArr->a[j+1]=t;
  53. }
  54.                 }
  55. }
复制代码

scanf("%s",&pArr->a[i]);为什么是%s才行,而我想输入%c,但是%c就只能输入2个字母,可输入的是%s进行排序又不行
总之我是想对一个数组先自己输入几个字母后,再选定位置插入字母后排序
请大神告诉我该怎么改,谢谢
小甲鱼最新课程 -> https://ilovefishc.com
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2025-11-15 20:17

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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