ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

实验6 指针

2022-06-13 21:34:37  阅读:123  来源: 互联网

标签:int s2 s1 char 实验 printf include 指针


task1_1.c

 1 #include<stdio.h>
 2 #define N 4
 3 
 4 int main()
 5 {
 6     int x[N]={1,9,8,4};
 7     int i;
 8     int *p;
 9     
10     p=x;
11     for(i=0;i<N;++i)
12         printf("%d",*(p+i));
13     printf("\n");
14     
15     return 0;
16 } 

task1_2.c

 1 #include<stdio.h>
 2 #define N 4
 3 
 4 int main()
 5 {
 6     char x[N]={'1','9','4','8'};
 7     int i;
 8     char *p;
 9     
10     p=x;
11     for(i=0;i<N;++i)
12         printf("%c",*(p+i));
13     printf("\n");
14     
15     return 0;
16 }

1.2004

2.2001

3.task1_1指向整型变量,占用4四字节;task1_2指向字符型变量,占用1字节。

 

task2_1.c

 1 #include<stdio.h>
 2 
 3 int main()
 4 {
 5     int x[2][4]={{1,9,8,4},{2,0,2,1}};
 6     int i,j;
 7     int *p;
 8     int(*q)[4];
 9     
10     for(i=0;i<2;++i)
11     {
12         for(j=0;j<4;++j)
13             printf("%d",x[i][j]);
14             printf("\n");
15     } 
16     
17     for(p=&x[0][0],i=0;p<&x[0][0]+8;++p,i++)
18     {
19         printf("%d",*p);
20         if((i+1)%4==0)
21             printf("\n");
22     }
23     
24     for(q=x;q<x+2;++q)
25     {
26         for(j=0;j<4;++j)
27             printf("%d",*(*q+j));
28             printf("\n");
29     }
30     
31     return 0;
32 } 

 

 task2_2.c

 1 #include<stdio.h>
 2 
 3 int main()
 4 {
 5     char x[2][4]={{'1','9','8','4'},{'2','0','2','1'}};
 6     int i,j;
 7     char *p;
 8     char (*q)[4];
 9     
10     for(i=0;i<2;++i)
11     {
12         for(j=0;j<4;++j)
13             printf("%c",x[i][j]);
14             printf("\n");
15     } 
16     
17     for(p=&x[0][0],i=0;p<&x[0][0]+8;++p,i++)
18     {
19         printf("%c",*p);
20         if((i+1)%4==0)
21             printf("\n");
22     }
23     
24     for(q=x;q<x+2;++q)
25     {
26         for(j=0;j<4;++j)
27             printf("%c",*(*q+j));
28             printf("\n");
29     }
30     
31     return 0;
32 } 

 

1.2004 2016

2.2001 2004

3.p指向元素的地址,q指向行地址

 

task3_1.c

 1 #include<stdio.h>
 2 #include<string.h>
 3 #define N 80
 4 
 5 int main()
 6 {
 7     char s1[]="C,I love u.";
 8     char s2[]="C,I hate u.";
 9     char tmp[N];
10     
11     printf("sizeof(s1) vs. strlen(s1):\n");
12     printf("sizeof(s1)=%d\n",sizeof(s1));
13     printf("strlen(s1)=%d\n",strlen(s1));
14     
15     printf("\nbefore swap:\n");
16     printf("s1: %s\n",s1);
17     printf("s2: %s\n",s2);
18     
19     printf("\nswapping...\n");
20     strcpy(tmp,s1);
21     strcpy(s1,s2);
22     strcpy(s2,tmp);
23     
24     printf(" \nafter swap: \n");
25     printf("s1: %s\n",s1);
26     printf("s2: %s\n",s2);
27     
28     return 0;
29 }

 

 1.s1的大小为13字节,sizeof(s1)计算s1的储存空间,strlen(s1)统计字节长度

2.不可以,定义错误

3.是

 

task3_2.c

 1 #include<stdio.h>
 2 #include<string.h>
 3 #define N 80
 4 
 5 int main()
 6 {
 7     char *s1="C,I love u.";
 8     char *s2="C,I hate u.";
 9     char *tmp;
10     
11     printf("sizeof(s1) vs. strlen(s1):\n");
12     printf("sizeof(s1)=%d\n",sizeof(s1));
13     printf("strlen(s1)=%d\n",strlen(s1));
14     
15     printf("\nbefore swap:\n");
16     printf("s1: %s\n",s1);
17     printf("s2: %s\n",s2);
18     
19     printf("\nswapping...\n");
20     tmp=s1;
21     s1=s2;
22     s2=tmp;
23     
24     printf(" \nafter swap: \n");
25     printf("s1: %s\n",s1);
26     printf("s2: %s\n",s2);
27     
28     return 0;
29 }

 

1.s1存放字符串的地址,sizeof(s1)计算字符串地址占用的储存空间,strlen(s1)统计字符串长度

2.不能,s1是地址,不能赋值

3.交换的是指针地址,存储单元没有交换

 

task4.c

 1 #include<stdio.h>
 2 #include<string.h>
 3 #define N 5
 4 
 5 int check_id(char *str);
 6 
 7 int main()
 8 {
 9     char *pid[N]={"31010120000721656X","330106199609203301",
10                   "53010220051126571","510104199211197977",
11                   "53010220051126133Y"};
12     int i;
13     
14     for(i=0;i<N;++i)
15         if(check_id(pid[i]))
16             printf("%s\tTrue\n",pid[i]);
17         else
18             printf("%s\tFalse\n",pid[i]);
19     
20     return 0;
21 } 
22 
23 int check_id(char *str)
24 {
25     int i,j;char temp[20];
26     for(i=0;i<N;i++)
27     {
28         if(strlen(str)!=18)
29             return 0;
30         
31         strcpy(temp,str);
32         for(j=0;j<strlen(str)-1;j++)
33         {
34             switch(temp[j]>'0'&&temp[j]<'9')
35             {
36                 case 1:if((temp[17]>'0'&&temp[17]<'9')||temp[17]=='X')
37                        {
38                              return 1;
39                        }
40                        else
41                        {
42                                return 0;
43                        }
44                 case 0:return 0;
45             }
46         }
47     } 
48 }

 

 task5.c

 1 #include<stdio.h>
 2 #include<string.h>
 3 
 4 #define N 80
 5 int is_palindrome(char *s);
 6 
 7 int main()
 8 {
 9     char str[N];
10     int flag;
11     
12     printf("Enter a string:\n");
13     gets(str);
14     
15     flag=is_palindrome(str);
16     
17     if(flag)
18         printf("YES\n");
19     else
20         printf("NO\n");
21         
22     return 0;
23 } 
24 
25 int is_palindrome(char *s)
26 {
27     int i;
28     for(i=0;i<strlen(s)/2;i++)
29     {
30         if(s[i]!=s[strlen(s)-1-i])
31         {
32             return 0;
33             break;
34         }
35     }
36     return 1;
37 }

 

 

 

 task6.c

 1 #include<stdio.h>
 2 #define N 80
 3 
 4 void encoder(char *s);
 5 void decoder(char *s);
 6 
 7 int main()
 8 {
 9     char words[N];
10     printf("输入英文文本:");
11     gets(words);
12     
13     printf("编码后的英文文本:");
14     encoder(words);
15     printf("%s\n",words);
16     
17     printf("对编码后的英文文本解码:");
18     decoder(words);
19     printf("%s\n",words);
20     
21     return 0;
22 }
23 
24 void encoder(char *s)
25 {
26     int i;
27     for(i=0;s[i]!='\0';i++)
28     {
29         if((s[i]>='a'&&s[i]<'z')||(s[i]>='A'&&s[i]<'Z'))
30         {
31             s[i]+=1;
32         }
33         else if(s[i]=='z')
34         {
35             s[i]='a';
36         }
37         else if(s[i]=='Z')
38         {
39             s[i]='A';
40         }
41     }
42 }
43 
44 void decoder(char *s)
45 {
46     int i;
47     for(i=0;s[i]!='\0';i++)
48     {
49         if((s[i]>'a'&&s[i]<='z')||(s[i]>'A'&&s[i]<='Z'))
50         {
51             s[i]=s[i]-1;
52         }
53         else if(s[i]=='a')
54         {
55             s[i]='z';
56         }
57         else if(s[i]=='A')
58         {
59             s[i]='Z';
60         }
61     }
62 }

 

标签:int,s2,s1,char,实验,printf,include,指针
来源: https://www.cnblogs.com/jby83300823/p/16372346.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有