实现strlen、strcpy函数
#include
#include
int mystrlen(char *s);
char * mystrcpy(char *dest,char *src);
int main(int argc, const char *argv[])
{
char a[100]={0};
char b[100]={0};
printf("input a--->");
gets(a);
printf("input b--->");
gets(b);
char *s = a;
char *t = b;
printf("a len = %d\n",mystrlen(s));
printf("b len = %d\n",mystrlen(t));
printf("strcopy前a\n");
puts(a);
printf("strcopy前b\n");
puts(b);
mystrcpy(t,s);
printf("strcopy(b,a)后a\n");
puts(a);
printf("strcopy(b,a)后b\n");
puts(b);
return 0;
}
int mystrlen(char *s)
{
char *p = s;
int n=0;
while(*p++ !='\0')
{
n++;
}
return n;
}
char * mystrcpy(char *dest,char *src)
{
char *d = dest;
while(*d++ = *src++);
return dest;
}
一、选择题(每题2分,共 50 分)
A、% B、/ C、%和/ D、*
A、(x>=y)&&(y>=z) B、(x>=y)AND(y>=z) C、(x>=y>=z) D、(x>=y)&(y>=z)
}
A、0 B、1 C、3 D、不确定的值
A、2.5 B、 2.0 C、 3 D、 2
A、00011011 B、00010100 C、00011100 D、00011000
A、为0 B、为1 C、不为0 D、不为1
float f, *pf=f; B、float f, *pf=&f; C、float *pf=&f, f; D、float f, pf=f;
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
A、x || y B、x | y C、x & y D、x ^ y
char a[]=“ABCDEF”; char b[]={ ‘A’,’B’,’C’,’D’,’E’,’F’};
则以下叙述正确的是 D 。
A、a和b数组完全相同 B、a和b长度相同
C、a和b中都存放字符串 D、a数组比b数组长度长
A、p B、*p C、x D、*&x
A、gets(a,b); B、scanf(“%s%s”,a,b);
C、scanf(“%s%s”,&a,&b); D、gets(“a”),gets(“b”);
A、s+1 B、 s++ C、&s[0]+1 D、 &s[1]
#inlcude
#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
#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
A、*p2=&x; B、p2=p1; C、p2=*p1; D、p2=&p1;
A、a[2][0] B、a[2][1] C、a[2][2] D、a[2][3]
A、116 B、118 C、144 D、122
A、p+=2, *p++ B、p+=2, *++p C、p+=2, (*p)++ D、a+=2, *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} };
A、字符’c’ B、字符’b’ C、字符’a’ D、字符’d’
A、k=*ptr1+*ptr2; B、ptr2=k;
C、ptr1=ptr2; D、k=*ptr1*(*ptr2);
A、a[i++] B、a[i]++ C、a[i] D、a[++i]
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
#include
void mpx(int arr[], int n)
{
int i, j, temp;
for (i = 0; i < n-1; i++) {
for (j = 0; j < n-i-1; j++) {
if (arr[j] > arr[j+1]) {
temp = arr[j];
arr[j] = arr[j+1];
arr[j+1] = temp;
}
}
}
}
int main(int argc, const char *argv[])
{
int arr[10];
int i;
printf("请输入10个整数:\n");
for (i = 0; i < 10; i++) {
scanf("%d", &arr[i]);
}
mpx(arr, 10);
printf("排序后的数组:\n");
for (i = 0; i < 10; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
2. 编写strcpy函数
已知strcpy函数的原型是 char *strcpy(char *strDest, const char *strSrc);
strDest是目的字符串,strSrc是源串。(不调用C的字符串库函数,编写函数 strcpy)
以char *mystrcpy(char *dest, char *src)作为函数声明。
char * mystrcpy(char *dest,char *src)
{
char *d = dest;
while(*d++ = *src++);
return dest;
}
3. 有一个3×4的矩阵,要求输出其最大值以及它的行号和列号。
int a[3][4] = {
{123, 94, -10, 218},
{3, 9, 10, -83},
{45, 16, 44, -99}
};
#include
#include
int main(int argc, const char *argv[])
{
int a[3][4] = {
{123,94,-10,218},
{3,9,10,-83},
{45,16,44,-99}
};
int (* p)[4]=a;
int max = a[0][0];
int row=0,col=0;
int i=0,j=0;
for(;i<3;i++)
{
for(;j<4;j++)
{
if(**((p+i)+j)>max)
{
max=**((p+i)+j);
row=i;
col=j;
}
}
}
printf("The largest value is %d at (%d,%d)\n",max,row+1,col+1);
return 0;
}
4. 写一个函数,统计一个unsigned int类型的值中有多少位为1
#include
#include
int uintw(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;
}
int main(int argc, const char *argv[])
{
unsigned int a=0;
scanf("%u",&a);
printf("位1--->%d个\n",uintw(a));
return 0;
}
5. 给定一个字符串“I love china”,编写程序完成以单词为单位的逆序,如“china love i”,并要求不允许使用第三方变量保存数据,但可以使用辅助指针变量等。
#include
#include
char *fun(char *le,char *ri)
{
char temp = 0;
while(le