实验5

#include<stdio.h>
#include<stdlib.h>
#define N 4
int main()
{
 int x[N]={1,9,8,4};
 int i;
 int *p;
 //方法一:数组名和下标
 for(i=0;i<N;++i)
  printf("%d",x[i]);
 printf("\n");
 //写法二:指针  (写法一)
 for(p=x;p<x+N;++p)
  printf("%d",*p);
 printf("\n");
 //方式二:指针变量
 p=x;
 for(i=0;i<N;++i)
  printf("%d",*(p+i));
 printf("\n");
 //方法二:指针(写法三)
 p=x;
 for(i=0;i<N;++i)
  printf("%d",p[i]);
 printf("\n");
 system("pause");
 return 0;
}

TEST2

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define N 80
int main ()
{
 char s1[]="Learning makes me happy";
 char s2[]="Learning makes me sleepy";
 char tmp[N];
 printf("sizeof(s1) vs. strlen(s1):\n");
 printf("sizeof(s1)=%d\n",sizeof(s1));
 printf("strlen(s1)=%d\n",strlen(s1));
 printf("\nbefore swap:\n");
 printf("s1:%s\n",s1);
 printf("s2:%s\n",s2);
 printf("\nswapping...\n");
 strcpy(tmp,s1);
 strcpy(s1,s2);
 strcpy(s2,tmp);
 printf("\nafter swap:\n");
 printf("s1:%s\n",s1);
 printf("s2:%s\n",s2);
 system("pause");
 return 0;
}

1:大小24,sizeof计算所占空间的大小,strlen统计字符长度
2:不可以,s1表示的是一个地址
3:交换了
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#define N 80
int main ()
{
 char *s1="Learning makes me happy";
 char *s2="Learning makes me sleepy";
 char *tmp;
 printf("sizeof(s1) vs. strlen(s1):\n");
 printf("sizeof(s1)=%d\n",sizeof(s1));
 printf("strlen(s1)=%d\n",strlen(s1));
 printf("\nbefore swap:\n");
 printf("s1:%s\n",s1);
 printf("s2:%s\n",s2);
 printf("\nswapping...\n");
 strcpy(tmp,s1);
 strcpy(s1,s2);
 strcpy(s2,tmp);
 printf("\nafter swap:\n");
 printf("s1:%s\n",s1);
 printf("s2:%s\n",s2);
 system("pause");
 return 0;
}

1:字符串的地址,sizeof(s1)s1空间大小,strlen(s1)s1字符长度

2:可以,2.1中s1是一个地址常量,不可以改变,而2.2中s1是一个指针变量,可以通过s1来在其指代的地址内存放字符串。

3:改变三个指针变量指代的地址。没有交换。

TEST3

#include<stdio.h>
#include<stdlib.h>
void str_cpy(char *target,const char *source);
void str_cat(char *str1,char *str2);
int main()
{
 char s1[80],s2[20]="1984";
 str_cpy(s1,s2);
 puts(s1);
 str_cat(s1,"Animal Farm");
 puts(s1);
 system("pause");
 return 0;
}
void str_cpy(char *target,const char *source)
{
 while(*target++ = *source++)
  ;
}
void str_cat(char *str1,char *str2)
{
 while(*str1)
  str1++;
 while(*str1++ = *str2++)
  ;
}

TEST4

#include<stdio.h>
#include<stdlib.h>
#define N 80
int func(char *);
int main()
{
 char str[80];
 while (gets(str)!=NULL)
 {
  if (func(str))
   printf("yes\n");
  else
   printf("no\n");
 }
 system("pause");
 return 0;
}
int func(char *str)
{
 char *begin,*end;
 begin =end =str;
 while(*end)
  end++;
 end--;
 while (begin<end)
 {
  if(*begin != *end)
   return 0;
  else
  {
   begin++;
   end--;
  }
 }
 return 1;
}

TEST5

#include<stdio.h>
#define N 80
#include<stdlib.h>
void func(char*);
int main()
{
 char s[N];
 while(scanf("%s",s)!=EOF)
 {
  func(s);
  puts(s);
 }
 return 0;
}
void func(char *str)
{
 int i;
 char *p1,*p2,*p;
 p1=str;
 while (*p1=='*')
  p1++;
 p2=str;
 while (*p2)
  p2++;
 p2--;
 while (*p2=='*')
  p2--;
 p=str;
 i=0;
 while(p<p1)
 {
  str[i]=*p;
  p++;
  i++;
 }
 while(p<=p2)
 {
  if(*p!='*')
  {
   str[i]=*p;
   i++;
  }
 p++;
 }

while(*p!='\0')
{
 str[i]=*p;
 p++;
 i++;
}
str[i]='\0';
}

TEST6

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
void sort(char *name[],int n);

int main()
{
    char *course[4]={"C program",
    "C++ Object Oriented Program",
    "Operating System",
    "Data Structure and Algorithms"};

    int i;

    sort(course,4);

    for(i=0;i<4;i++)
        printf("%s\n",course[i]);

    system("pause");
    return 0;
}

void sort(char *name[],int n)
{
    int i,j;
    char *tmp;

    for(i=0;i<n-1;++i)
        for(j=0;j<n-1-i;++j)
            if(strcmp(name[j],name[j+1])>0)
            {
                tmp=name[j];
                name[j]=name[j+1];
                name[j+1]=tmp;
            }
}

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
void sort(char *name[],int n);

int main()
{
    char *course[4]={"C program",
    "C++ Object Oriented Program",
    "Operating System",
    "Data Structure and Algorithms"};
    
    int i;

    sort(course,4);

    for(i=0;i<4;i++)
        printf("%s\n",course[i]);

    system("pause");
    return 0;
}

void sort(char *name[],int n)
{
    int i,j,k;
    char *tmp;

    for(i=0;i<n-1;++i)
    {
        k=i;
        for(j=i+1;j<n;j++)
            if(strcmp(name[j],name[k])<0)
            k=j;

        if(k!=i)
        {
            tmp=name[i];
            name[i]=name[k];
            name[k]=tmp;
        }
}
}

交换的是指针变量的值

TEST7

#include <stdio.h>
#include<stdlib.h>
#include <string.h>
#define N 5

int check_id(char *str); // 函数声明

int main()
{
char *pid[N] = {"31010120000721656X",
"330106199609203301",
"53010220051126571",
"510104199211197977",
"53010220051126133Y"};
int i;

for (i = 0; i < N; ++i)
if (check_id(pid[i])) // 函数调用
printf("%s\tTrue\n", pid[i]);
else
printf("%s\tFalse\n", pid[i]);

system("pause");
return 0;
}

// 函数定义
// 功能: 检查指针str指向的身份证号码串形式上是否合法。
// 形式合法,返回1,否则,返回0
int check_id(char *str)
{
int flag=1,i,num;

for(num=0;str[num]!='\0';)
num++;

if(num!=18)
flag=0;

for(i=0;i<18;)
{
if((str [i]>=48 && str[i]<=58) ||str[i]=='X')
i++;
else
break;
}
if(i<18)
flag=0;

return flag;
}

 

TEST8

#include <stdio.h>
#include<stdlib.h>
#define N 80
void encoder(char *s); // 函数声明
void decoder(char *s); // 函数声明

int main()
{
    char words[N];

    printf("输入英文文本: ");
    gets(words);

    printf("编码后的英文文本: ");
    encoder(words); // 函数调用
    printf("%s\n", words);

    printf("对编码后的英文文本解码: ");
    decoder(words); // 函数调用
    printf("%s\n", words);

    system("pause");
    return 0;
}

/*函数定义
功能:对s指向的字符串进行编码处理
编码规则:
对于a~z或A~Z之间的字母字符,用其后的字符替换; 其中,z用a替换,Z用A替换
其它非字母字符,保持不变
*/
void encoder(char *s)
{
    int i=0;
    for(;s[i]!='\0';i++)
    {
        if((s[i]>='a'&&s[i]<'z')||(s[i]>='A'&&s[i]<'Z'))
            s[i]=s[i]+1;
        else
        {
        if(s[i]=='z')
            s[i]='a';
        else
            if(s[i]=='Z')
            s[i]='A';
        }
    }
}

/*函数定义
功能:对s指向的字符串进行解码处理
解码规则:
对于a~z或A~Z之间的字母字符,用其前面的字符替换; 其中,a用z替换,A用Z替换
其它非字母字符,保持不变
*/
void decoder(char *s)
{
       int i=0;
    for(;s[i]!='\0';i++)
    {
        if((s[i]>'a'&&s[i]<='z') ||(s[i]>'A'&&s[i]<='Z'))
            s[i]=s[i]-1;
        else
        {if(s[i]=='a')
            s[i]='z';
        else
            if(s[i]=='A')
            s[i]='Z';}
    }
    
}

 

 

posted @ 2023-05-07 01:05  超级peipei  阅读(33)  评论(0)    收藏  举报