首页 > 其他分享 >实验五

实验五

时间:2023-05-07 23:23:24浏览次数:36  
标签:int s1 char 实验 str printf include

task1.1

程序源码

#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;
}

  

实验截图

 

task1.2

程序源码

int main()
{
	int x[2][4]={{1,9,8,4},{2,0,4,9}};
	int i, j;
	int *p;
	int (*q)[4];

	for(i=0;i<2;++i)
	{
		for(j=0;j<4;++j)
			printf("%d",x[i][j]);
		printf("\n");
		for(p=&x[0][0],i=0;p<&x[0][0]+8;++p,++i)
		{
			printf("%d",*p);
			if((i+1)%4==0)
				printf("\n");}
		for(q=x;q<x+2;++q)
		{for(j=0;j<4;++j)
		printf("%d",*(*q+j));
		printf("\n");}
				system("pause");
	return 0;
}

  

实验截图

 

task2.1

程序源码

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

int main(){
	char s1[]="Learning makes me happy";
	char s2[]="Learning makes me happy";
	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.数组s1的大小为23,sizeof计算占据多少字节,strlen计算字节长度

2.不能,s1是一个数组

3.完成了交换

task2.2

程序源码

#include<stdio.h>
#include<string.h>
#include<stdlib.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");
	tmp=s1;
	s1=s2;
	s2=tmp;

	printf("\nafter swap:\n");
	printf("s1:%s\n",s1);
	printf("s2:%s\n",s2);

	system("pause");
	return 0;
}

  

实验截图

 1.s1中存放字符串的起始地址,sizeof(s1)计算的是数组所占的字节数,strlen(s1)统计的是数组的长度

2.可以,指针可以指向赋予的一串字符

3.交换的是指针的指向,实际在储存单元中没有被交换

task3

程序源码

#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++)
		;}

  

实验截图

 

task4

程序源码

#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;}

  

实验截图

 

task5

程序源码

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--;

	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';
}

  

实验截图

 

task6.1

程序源码

#include<stdio.h>
#include<string.h>
#include<stdlib.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;
			}
}

  

实验截图

 

task6.2

程序源码

#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;
		}
	}
}

  

实验截图

 

task7

程序源码

#include <stdio.h>
#include <string.h>
#include<stdlib.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 i=0,j=0;
	char *p;
	p=str;
    if(strlen(str)!=18)
			i++;
	while(*p>='0'&&*p<='9'||*p=='X')
		p++;
   if(*p=='\0'&&i==0)
	   return 1;
   else
	   return 0;
}

  

实验截图

 

task8

程序源码

#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)
{while(*s){
       if(*s>=65&&*s<90||*s>=97&&*s<122){
              *s=*s+1;
              s++;continue;
       }
       else if(*s==90||*s==122){
              *s=*s-25;
              s++;continue;
       }
       s++;
}
 return;
    
}

/*函数定义
功能:对s指向的字符串进行解码处理
解码规则:
对于a~z或A~Z之间的字母字符,用其前面的字符替换; 其中,a用z替换,A用Z替换
其它非字母字符,保持不变
*/
void decoder(char *s)
{
   while(*s){
       if(*s>=66&&*s<90||*s>=98&&*s<122){
              *s=*s-1;
              s++;continue;
       }
       else if(*s==65||*s==97){
              *s=*s+25;
              s++;continue;
       }
       s++;
}    return;
}

  

实验截图

 

标签:int,s1,char,实验,str,printf,include
From: https://www.cnblogs.com/dmdshuangxu/p/17380417.html

相关文章

  • 实验二 电子公文传输系统安全--读书笔记
    实验二电子公文传输系统安全--读书笔记一、《Core.Software.Security.Security.at.the.Source.CN.软件安全.从源头开始》安全开发生命周期最著名的SDL模型是可信计算安全开发生命周期,受欢迎的SDL模型有微软的SDL、Cigital的软件安全触点模型、OWASPSDL、思科的安全开发生命......
  • 实验五
    task1#include<stdio.h>#defineN4intmain(){ intx[N]={1,9,8,4}; inti; 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(&q......
  • 实验5
    实验任务1:1.1#include<stdio.h>#defineN4intmain(){intx[N]={1,9,8,4};inti;int*p;for(i=0;i<N;i++)printf("%d",x[i]);printf("\n");for(p=x;p<x+N;++p)printf(......
  • lora串口通信实验
    记录一下lora串口通信的测试用的亿佰特E32170T30D(230的大概率也是一样的,后面测一下)+STM32F103(正点原子的mini,后面会改成小的stm32板子方便使用)+lora的TTL工具E15-USB-T2+电脑因为亿佰特的引脚很多,对于M0M1还有AUX这种配置工作状态的引脚先通过上位机软件配置好,然后就可以把lor......
  • ICP-MS/痕量元素分析实验需要的PFA耗材
    PFA(perfluoroalkoxy)isatough,flexible fluoropolymer thatisusedforflexibletubingandfluidprocessingequipmentwhenchemicalresistance,highpurity,andlowstiffnessarerequired.PFAhasoutstandingelectricalpropertiesincludinghighdielec......
  • 超净化实验室PFA亚沸腾酸纯化系统2000ml高纯酸制备
     酸纯化器:又称酸纯化系统,高纯酸提纯器,酸试剂提纯器,高纯酸蒸馏纯化器等,主要用于降低酸中金属元素含量,从而得到纯净度较好的实验酸。 二、工作原理:酸纯化器是利用热辐射原理,保持液体温度低于沸点温度蒸发,再将其酸蒸气冷凝从而制备高纯水和高纯试剂,广泛应用于样品处理及分析实......
  • Java实验十
    1importjava.io.*;2importjava.util.Arrays;3importjava.util.InputMismatchException;4importjava.util.Scanner;56publicclassAverageScore{7publicstaticvoidmain(String[]args)throwsIOException{8//System.out.println......
  • 实验5
    实验1.1运行代码#include<stdio.h>#defineN4intmain(){ intx[N]={1,9,8,4}; inti; int*p; for(i=0;i<N;++i) printf("%d",x[i]); printf("\n");//for(i=0;p<x+N;++p) //printf("%d",*p); //p......
  • 实验报告
    1、复数类Complex有两个数据成员:a和b,分别代表复数的实部和虚部,并有若干构造函数和一个重载-(减号,用于计算两个复数的距离)的成员函数。要求设计一个函数模板template<classT>doubledist(Ta,Tb)对int,float,Complex或者其他类型的数据,返回两个数据的间距。以上类名和函......
  • 20201230张国强实验三
    免杀原理1.基础问题回答杀软是如何检测出恶意代码的?基于特征码的静态扫描技术在文件中寻找特定的十六进制字符串,如果找到,就可判定文件感染了某种病毒。启发式杀毒技术病毒要达到感染和破坏的目的,通常的行为都会有一定的行为和特征,所以可以通过分析相关的病毒指令,判......