2.5作业

本文介绍了如何自己实现strlen和strcpy函数,以及C语言基础考试中的选择题和程序题,包括字符串操作、运算符、数组与指针等内容。
摘要由CSDN通过智能技术生成

1、自己实现strlen、strcpy函数

#include<stdio.h>
#include<string.h>
int mystrlen(char *s);
int main(int argc, const char *argv[])
{
	char arr[50]="0";
	char *ptr=arr;
	int len=0;
	printf("输入一串字符:");
	gets(arr);
	len=mystrlen(ptr);
	printf("长度为%d\n",len);
	return 0;
}

int mystrlen(char *s)
{
	int i=0;
	int len=0;
	char *pa=s;
	for(i=0;*(pa+i)!='\0';i++)
	{
		len++;
	}
	return len;
}

#include<stdio.h>
#include<string.h>
char *mystrcpy(char *s1,char *s2);
int main(int argc, const char *argv[])
{
	char arr[50]="0";
	char brr[50]="0";
	char *pa=arr;
	char *pb=brr;
	printf("输入第一串字符:");
	gets(arr);
	printf("输入第二串字符:");
	gets(brr);
	mystrcpy(pa,pb);
	printf("复制后为%s\n",pa);
	return 0;
}

char *mystrcpy(char *s1,char *s2)
{
	char *ptr=s1;
	char *str=s2;
	int i=0;
	for(i=0;*(str+i)!='\0';i++)
	{
		*(ptr+i)=*(str+i);
	}
	return ptr;
}

2、C基础考试题A卷

一、选择题(每题2分,共 50 分)

1.C语言中,运算对象必须是整型数的运算符是    A     

         A、%           B、/              C、%和/               D、*

2.若有关系x≥y≥z,应使用     A    C语言表达式。

A、(x>=y)&&(y>=z) B、(x>=y)AND(y>=z)  C、(x>=y>=z) D、(x>=y)&(y>=z)

3.下面程序的输出是   C      main(  )                                                        { int x=10,y=3;                                                            printf(“%d\n”,y=x/y);

}

A、0 B、1 C、3 D、不确定的值

4.若float x ;x = 10/4 ; x的值是     B     

A2.5         B 2.0        C 3         D  2

5.设有以下语句:int a=3,b=6,c; c=a^b<<2; 则c的二进制值是     A    

A、00011011   B、00010100    C、00011100    D、00011000

6.在位运算中,某操作数 右移3位,其结果相当于     D    

A、操作数乘以6   B、操作数除以6  C、操作数乘以8   D、操作数除以8

7.if(!x),要想表达式(!x真,x的值      A       。

A、为0       B1         C、不为0       D、不为1

8.下列语句定义pf为指向float类型变量f的指针,   B    是正确的。

float f, *pf=f; Bfloat f, *pf=&f; Cfloat *pf=&f, f; Dfloat f, pf=f;

9.执行下列程序段后,变量a,b,c的值分别是   D    

     int x=10,y=9;

     int a,b,c;

     a=(--x==y++)?--x:++y;

     b=x++; 

     c=y;

A、a=9,b=9,c=9   B、a=9,b=10,c=9  C、a=1,b=11,c=10  D、a=8,b=8,c=10

10.整型变量x和y的值相等,且为非0值,则以下选项中,结果为0的表达式是     D     

A、x || y   B、x | y   C、x & y    D、x ^ y

11.对两个数组a和b进行如下初始化

  char a[]=ABCDEF”;   char b[]={ ‘A’,’B’,’C’,’D’,’E’,’F’};

    则以下叙述正确的是    D     

A、a和b数组完全相同            B、a和b长度相同  

C、a和b中都存放字符串          D、a数组比b数组长度长

12.设变量定义为“int x, *p=&x;”,则&*p相当于    A    

Ap          B*p           Cx         D*&x

13.有两个字符数组a、b,则以下正确的输入语句是     B     

Agets(a,b);               Bscanf(“%s%s”,a,b);

Cscanf(“%s%s”,&a,&b);   Dgets(“a”),gets(“b”);

14.若已定义 char s[10]; 则在下面表达式中不表示s[1]的地址的是     B     

As+1     B s++      C&s[0]+1      D  &s[1]

15.以下程序的执行结果为     C      

#include <stdio.h> 

#define N 2     

#define M N+1

#define NUM (M+1)*M/2

 main()  

{pirntf("%d",NUM);}                                                 A、5     B、6      C、8       D、9 

16.以下程序的输出结果是    D      

#define M(x,y,z) x*y+z

main()  

{  int a=1,b=2, c=3;    

printf("%d\n", M(a+b,b+c, c+a)); }                                   A、19   B、17    C、15         D、12 

17.int x,*p1=&x, *p2;,则能使得p2也指向x的语句是    B       

A、*p2=&x;    B、p2=p1;           C、p2=*p1;    D、p2=&p1;

18.int a[5][4], *p=a[0];,则*(p+2*4+3)等于     D      

A、a[2][0]    B、a[2][1]          C、a[2][2]   D、a[2][3]

19.int a[5][4], (*p)[4]=a;,数组a的首地址为100,*(p+2)+3等于     C      

A、116    B、118            C、144    D、122

20.int a[]={1,3,5,7,9},*p=a;,则值为5的表达式是    A      

A、p+=2, *p++   B、p+=2, *++p     C、p+=2, (*p)++  D、a+=2, *a

21.以下对二维数组a的正确说明是      A     

A、 int a[ ][3]={ 0 };            B、int a[3][ ]={ {1},{2},{3} };

C、 int a[1][3]={ 1,2,3,4 };      D、int a[2][3]={ {1,2},{3,4},{5,6} };

22.已知:char s[4] = "cba"; char *p; 执行语句序列p=s; printf("%c\n",*(p+1));后,其输出为     D      

A、字符’c’   B、字符’b’    C、字符’a’ D、字符’d’

23.已有定义 int k=2; int *ptr1, *ptr2, 且ptr1和ptr2均已指向变量k , 下面不能执行的赋值语句是     B      

A、k=*ptr1+*ptr2;        B、ptr2=k;

C、ptr1=ptr2;          D、k=*ptr1*(*ptr2);

24.若有定义int i=2,a[10],*p=&a[i];则与*p++ 等价的是    A      

A、a[i++]   B、a[i]++   C、a[i]   D、a[++i]

25.下面函数fun的功能是    D      

int fun(char *s,char *t)

{  while(*s==*t)

if(*s==’\0’)

return 0;

else

s++,t++;

return *s-*t;

}

s:hello  t:welloe

A、测字符串s和t的长度  B、将字符串s拷贝到t

C、将字符串t拷贝到s   D、比较字符串s和t的大小

二、程序题(每题5分,共50分)

1.冒泡排序(要求:从终端获取十个数,升序排序);

#include<stdio.h>
#include<string.h>
int main(int argc, const char *argv[])
{
	int i=0,j=0;
	int temp=0;
	int arr[10];
	printf("输入十个数\n");
	for(i=0;i<10;i++)
	{
		printf("输入的第%d个数:",i+1);
		scanf("%d",&arr[i]);
	}
	for(i=1;i<=9;i++)
	{
		for(j=0;j<10-i;j++)
		{
			if(arr[j]>arr[j+1])
			{
				temp=arr[j];
				arr[j]=arr[j+1];
				arr[j+1]=temp;
			}
		}
	}
	for(i=0;i<10;i++)
	{
		printf("%-5d",arr[i]);
	}
	putchar(10);
	return 0;
}

2. 编写strcpy函数

已知strcpy函数的原型是 char *strcpy(char *strDest, const char *strSrc);

strDest是目的字符串,strSrc是源串。(不调用C的字符串库函数,编写函数 strcpy)

以char *mystrcpy(char *dest, char *src)作为函数声明。

#include<stdio.h>
#include<string.h>
char *mystrcpy(char *dest, char *src);
int main(int argc, const char *argv[])
{
	char arr[50]="0";
	char brr[50]="0";
	char *pa=arr;
	char *pb=brr;
	printf("输入第一串字符:");
	gets(arr);
	printf("输入第二串字符:");
	gets(brr);
	mystrcpy(pa,pb);
	printf("%s\n",pa);
	return 0;
}

char *mystrcpy(char *dest, char *src)
{
	char *str=dest;
	while(*str++=*src++);
	return str;
}

3. 有一个3×4的矩阵,要求输出其最大值以及它的行号和列号。

       int a[3][4] = {

              {123, 94, -10, 218},

              {3, 9, 10, -83},

              {45, 16, 44, -99}

       };

#include<stdio.h>
#include<string.h>
int main(int argc, const char *argv[])
{
	int a[3][4]={
		{123,94,-10,218},
		{3,9,10,-83},
		{45,16,44,-99}
	};
	int max=0;
	int hang=0;
	int lie=0;
	int i=0,j=0;
	max=a[0][0];
	for(i=0;i<3;i++)
	{
		for(j=0;j<4;j++)
		{
			if(max<a[i][j])
			{
				max=a[i][j];
				hang=i+1;
				lie=j+1;
			}
		}
	}
	printf("最大值为%d  它的行号是%d  它的列号是%d\n",max,hang,lie);
	return 0;
}

4. 写一个函数,统计一个unsigned int类型的值中有多少位为1

#include<stdio.h>
#include<string.h>
int statistic_1(unsigned int data)
{
    int count=0, temp=data;
    int i=0;
    for(i=0; i<32; i++)
    {   
        if(1 == (temp&1))
        {   
            count++;
        }   
        temp = temp>>1;
    }   
    return count;
}

5. 给定一个字符串“I love china”,编写程序完成以单词为单位的逆序,如“china love i”,并要求不允许使用第三方变量保存数据,但可以使用辅助指针变量等。

#include<stdio.h>
#include<string.h>
int main(int argc, const char *argv[])
{
	char arr[50]="I  love china";
	int len=strlen(arr);
	char temp1=0,temp2=0;
	int i=0,j=0,k=0;
	char *pa=arr;
	char *start=arr;
	char *end=arr+len-1;
	while(start<end)
	{
		temp1=*start;
		*start=*end;
		*end=temp1;
		start++;
		end--;
	}
	printf("%s\n",arr);
	for(i=0;*(pa+i)!='\0';i++)
	{
		if(*(pa+i)==' '||*(pa+i)=='\0')
		{
			for(k=i-1;j<k;j++,k--)
			{
				temp2=*(pa+j);
				*(pa+j)=*(pa+k);
				*(pa+k)=temp2;
			}
			j=i+1;
		}
	}
	printf("%s\n",pa);
	return 0;
}

  • 15
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
PM2.5实时信息管理系统数据结构作业是一个基于数据结构的项目,旨在实现对PM2.5数据的实时管理和分析。该系统需要设计适合高效存储和处理PM2.5数据的数据结构,并能提供实时查询和统计功能。 首先,我们可以使用一个二维数组来存储PM2.5数据。数组的行数代表不同的城市,列数代表不同的时间段。每个元素存储对应城市和时间段的PM2.5值。通过使用数组,我们可以高效地存储和访问PM2.5数据。 同时,我们还需要使用一个哈希表来存储每个城市对应的索引。哈希表的键是城市名称,值是对应城市在数组中的索引。这样可以快速根据城市名称找到对应的PM2.5数据。 为了支持实时查询和统计功能,我们可以使用二叉搜索树(BST)来存储每个时间段的PM2.5数据。BST的节点包含时间戳和对应的PM2.5值。通过将时间戳作为BST的键,我们可以高效地进行范围查询和统计操作。 另外,我们还可以使用一个优先队列来存储城市之间的PM2.5数据。优先队列根据PM2.5值的大小进行优先级排序,可以方便地找到PM2.5值最大或最小的城市。通过使用优先队列,我们可以实时监控和管理PM2.5数据。 综上所述,PM2.5实时信息管理系统的数据结构可以包括二维数组、哈希表、二叉搜索树和优先队列。这些数据结构的设计和优化将使系统能够高效地管理和分析PM2.5数据,为用户提供实时查询和统计功能。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值