浙江中医药大学-《数据结构》-串、数组算法设计

ZCMU-Data Structure-String and Array
1、写一个递归算法来实现字符串逆序存储,要求不另设串存储空间。

实现字符串的逆置并不难,但本题“要求不另设串存储空间”来实现字符串逆序存储,即第一个输入的字符最后存储,最后输入的字符先存储,使用递归可容易做到。

void InvertStore(char A[])
//字符串逆序存储的递归算法。
{char ch;
static int i = 0;//需要使用静态变量
cin>>ch;
if (ch!= '.')    //规定'.'是字符串输入结束标志
	{InvertStore(A);
	 A[i++] = ch;//字符串逆序存储
	}
A[i] = '\0';  //字符串结尾标记
}

2、编写算法,实现下面函数的功能。函数void insert(char*s,char*t,int pos)将字符串t插入到字符串s中,插入位置为pos。假设分配给字符串s的空间足够让字符串t插入。(说明:不得使用任何库函数)

本题是字符串的插入问题,要求在字符串s的pos位置,插入字符串t。首先应查找字符串s的pos位置,将第pos个字符到字符串s尾的子串向后移动字符串t的长度,然后将字符串t复制到字符串s的第pos位置后。

对插入位置pos要验证其合法性,小于1或大于串s的长度均为非法,因题目假设给字符串s的空间足够大,故对插入不必判溢出。

void  insert(char *s,char *t,int pos)
//将字符串t插入字符串s的第pos个位置。
{int i=1,x=0;  char *p=s,*q=t;  //p,q分别为字符串s和t的工作指针
 if(pos<1) {cout<<“pos参数位置非法”<<endl;exit(0);}
while(*p!=’\0’&&i<pos) {p++;i++;} //查pos位置
 //若pos小于串s长度,则查到pos位置时,i=pos。
 if(*p == '/0') { cout<<pos<<"位置大于字符串s的长度";exit(0);}
 else      //查找字符串的尾
   while(*p!= '/0') {p++; i++;}  //查到尾时,i为字符‘\0’的下标,p也指向‘\0’。
 while(*q!= '\0') {q++; x++; }   //查找字符串t的长度x,循环结束时q指向'\0'。
 for(j=i;j>=pos ;j--){*(p+x)=*p; p--;}//串s的pos后的子串右移,空出串t的位置。
 q--;  //指针q回退到串t的最后一个字符
 for(j=1;j<=x;j++) *p--=*q--;  //将t串插入到s的pos位置上
3、设任意n个整数存放于数组A(1:n)中,试编写算法,将所有正数排在所有负数前面(要求算法复杂度为0(n))。

本题属于排序问题,只是排出正负,不排出大小。可在数组首尾设两个指针i和j,i自小至大搜索到负数停止,j自大至小搜索到正数停止。然后i和j所指数据交换,继续以上过程,直到i=j为止。

void Arrange(int A[],int n) 
//n个整数存于数组A中,本算法将数组中所有正数排在所有负数的前面
{int i=0,j=n-1,x;  //用类C编写,数组下标从0开始
 while(i<j)
{while(i<j && A[i]>0)  i++;
while(i<j && A[j]<0)  j--;
   if(i<j) {x=A[i]; A[i++]=A[j]; A[j--]=x; }//交换A[i] 与A[j]
}// while(i<j)
 }//算法Arrange结束.



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值