原先設計的SSTRING結構是不需要使用'\0'作字符串結束符的。

授人以渔,不授人以鱼。
程序代码:#include<stdio.h>
#include<stdlib.h>
#define MAXSIZE 256 //定义串允许的最大字符个数
typedef struct
{
char string[MAXSIZE]; //MAXSIZE为串的最大长度
int len; //串的实际长度
}SSTRING; //串的顺序存储结构表示
int str_len(SSTRING *s) //串的长度计算函数
{
;
}
void str_input(SSTRING *s) //串的输入函数
{
int i=0;
char ch;
s->len=0;
while((ch=getchar())!='\n') //通过循环,从键盘输入一串字符串
{
s->string[i]=ch;
i++;
s->len++;
}
s->string[i]='\0';
}
SSTRING *str_rep(SSTRING *s1,SSTRING *s2,int pos)
{ //将字符串S1从pos位置处替换S2串
int i=0,j;
for(j=pos-1;s1->string[j]!='\0';j++) //从替换的起始位置开始
if(s2->string[i]!='\0')
{
; //进行替换
i++;
}
else
{
break;
}
return s1;
}
SSTRING *str_con(SSTRING *s1,SSTRING *s2)
{ //将字符串S2连接到S1串的后面,两个串合并成一个串,放到S1串中
int i=s1->len,j=0,k;
for(k=0;k<str_len(s2);k++)
{
;
;
;// 通过循环,将S2串的元素逐一复制到S1串的后面,
;// 合并成一个串。
}
s1->string[i]='\0';
return s1;
}
SSTRING *str_sub(SSTRING *sub,SSTRING *s,int pos,int len)
{//将串S第pos个字符开始的长度为len的字符序列复制到串sub中
int i=pos-1,j=0,k;
for(k=1;k<=len;k++)
{
;//逐一取出S串中从pos开始的元素,并复制到sub串中
;//每复制完一个元素,sub串长度加1。
i++;
j++;
}
sub->string[j]='\0';
return sub;
}
void str_print(SSTRING *s)
{//字符串输出显示
int i;
for(i=0;i<s->len;i++)
;//依次将串中的字符逐一输出到屏幕显示。
printf("\n");
}
void showmenu()
{ //显示菜单
printf(" 欢迎使用串操作小软件\n");
printf("\t1、求串的长度\n");
printf("\t2、串的替换\n");
printf("\t3、串的连接\n");
printf("\t4、求子串\n");
printf("\t5、退出程序\n");
}
void main()
{
int position,length,no;
SSTRING str,str1,str2;
str.len=0;
str1.len=0,str2.len=0;
while(1)
{
showmenu();
printf(" 请输入你的选择:");
scanf("%d",&no);
switch(no)
{
case 1:printf("请输入一串字符:");
fflush(stdin);
str_input(&str);
length=str_len(&str);
printf("字符串:%s的长度为%d\n",str.string,length);
system("pause");
system("cls");
break;
case 2:printf("请输入源字符串:");
fflush(stdin);
str_input(&str1);
printf("请输入替换字符串:");
fflush(stdin);
str_input(&str2);
printf("请输入替换位置:");
scanf("%d",&position);
str_rep(&str1,&str2,position);
printf("替换后的结果为:");
str_print(&str1);
system("pause");
system("cls");
break;
case 3:printf("请输入第一串字符:");
fflush(stdin);
str_input(&str1);
printf("请输入第二串字符串:");
fflush(stdin);
str_input(&str2);
str_con(&str1,&str2);
printf("两串字符连接后的结果为:");
str_print(&str1);
system("pause");
system("cls");
break;
case 4:printf("请输入一串字符:");
fflush(stdin);
str_input(&str1);
printf("请输入取子串的位置和长度:");
scanf("%d%d",&position,&length);
str_sub(&str,&str1,position,length);
printf("子串为:");
puts(str.string);
system("pause");
system("cls");
break;
case 5:
return;
}
}
}
程序代码:#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
const int MAX_LENGTH = 256;
struct String
{
char Buffer[MAX_LENGTH];
int Length;
};
String String_Build(const char* str); // 使用cz字符串創建一個String串
void String_Show(String str); // 輸出String串的內容
String String_Attach(String str1, String str2); // 將str2串接到str1的後面
String String_Replace(String str1, String str2, int pos); // 用str2在指定位置pos處開始替換str1
void Pause(void);
int main(void)
{
String str1 = String_Build("YaoJiaLi ");
String str2 = String_Build("Hello, world!");
String_Show(String_Attach(str1, str2));
putchar('\n');
String_Show(String_Replace(str2, str1, 7));
Pause();
return EXIT_SUCCESS;
}
String String_Build(const char* str)
{
String string;
// 不管用代碼還是人工輸入創建String串,都要記得時刻檢查串長度是否超越極限!
string.Length = 0;
for (int index = 0; (str[index] != '\0') && (index < MAX_LENGTH); ++index)
{
string.Buffer[string.Length++] = str[index];
}
return string;
}
void String_Show(String str)
{
for (int index = 0; index < str.Length; ++index)
{
putchar(str.Buffer[index]);
}
}
String String_Attach(String str1, String str2)
{
String str = str1;
for (int index = 0; (index < str2.Length) && (str.Length < MAX_LENGTH); ++index)
{
str.Buffer[str.Length++] = str2.Buffer[index];
}
return str;
}
String String_Replace(String str1, String str2, int pos)
{
String str = str1;
if (pos < str1.Length)
{
for (int index = 0; (index < str2.Length) && (str.Length < MAX_LENGTH); ++index)
{
str.Buffer[pos + index] = str2.Buffer[index];
if (pos + index >= str.Length)
{
++str.Length;
}
}
}
return str;
}
void Pause(void)
{
printf_s("\nPress any key to continue...");
_getch();
}
