实验5

1.1(忘空行了)
#include<stdio.h> #define N 5 void output(int x[],int n); int main(){ int x[N]={9,55,30,27,22}; int i; int k;//记录最大元素的下标 int t;//交换两个数组元素的中间变量 printf("original array:\n"); output(x,N); k=0; for(i=0;i<N;i++) if(x[i]>x[k]) k=i; if(k!=N-1){ t=x[N-1]; x[N-1]=x[k]; x[k]=t; } printf("after swapped:\n"); output(x,N); return 0; } void output(int x[],int n){ int i; for(i=0;i<n;i++){ printf("%d ",x[i]); } printf("\n"); }

 

发生元素交换有1次。

 1.2

#include<stdio.h>
#define N 5

void output(int x[],int n);

int main(){
    int x[N]={9,55,30,27,22};
    int i;
    int t;//交换两组元素的中间变量
    printf("original array:\n");
    output(x,N);
    
    for(i=0;i<N-1;++i){
        if(x[i]>x[i+1]){
            t=x[i];
            x[i]=x[i+1];
            x[i+1]=t;
        }
    }
    printf("after swapped:\n");
    output(x,N);    
    return 0;
} 

void output(int x[],int n){
    int i;
    
    for(i=0;i<n;i++){
        printf("%d ",x[i]);
    }
    printf("\n");
}

 

 发生元素交换有3次。

1.1是通过改变k的下标实现x【k】最大,如果k不在最后一个就交换最后一个和x【k】,只要交换1次或0次;

1.2没有下标的改变,直接交换元素。

 

2.

#include<stdio.h>
#define N 5

int binarysearch(int x[],int n,int item);

int main()
{
    int a[N]={2,7,19,45,66};
    int i,index,key;
    
    printf("数组a中的数据:\n");
    for(i=0;i<N;i++)
        printf("%d ",a[i]);
    printf("\n");
    
    printf("输入待查找的数据项:");
    scanf("%d",&key);
    
    index=binarysearch(a,N,key);
    
    if(index>=0)
        printf("%d 在数组中,下标为%d\n",key,index);
    else
        printf("%d 不在数组中\n",key);
        
    return 0;
}

int binarysearch(int x[],int n,int item){
    int low,high,mid;
    
    low=0;
    high=n-1;
    
    while(low<=high){
        mid=(low+high)/2;
        if(x[mid]==item)
            return mid;
        else if(x[mid]>item)
            high=mid-1;
        else
            low=mid+1;
    }
    
    return -1;
}

 

 

 

 

 

 正确。

 

3.

#include<stdio.h>
#define N 5
void selectsort(int a[],int n);
void input(int a[],int n);
void output(int a[],int n);

int main(){
    int a[N];
    
    printf("输入%d个整数\n",N);
    input(a,N);
    
    printf("排序前的数据:\n");
    output(a,N);
    
    selectsort(a,N);
    
    printf("排序后的数据:\n");
    output(a,N);
    
    return 0;
}

void input(int a[],int n){
    int i;
    for(i=0;i<n;i++){
        scanf("%d",&a[i]);
    }
}
void output(int a[],int n){
    int i;
    for(i=0;i<n;i++){
        printf("%d ",a[i]);
    }
    printf("\n"); 
}
void selectsort(int a[],int n){
    int i,j,k,temp;
    for(i=0;i<n-1;i++){
        k=i;//k用于记录当前最小元素的下标
        for(j=i+1;j<n;j++){
            if(a[j]<a[k])
                k=j;
        } 
        if(k!=i){
            temp=a[i];
            a[i]=a[k];
            a[k]=temp;
        }
    }
}

 

 

#include<stdio.h>
#include<string.h>
#define N 5
void selectsort(char str[][20],int n);

int main(){
    char name[][20]={"Bob","Bill","Joseph","Talor","George"};
    int i;
    
    printf("输出初始名单:\n");
    for(i=0;i<N;i++)
        printf("%s\n",name[i]);
        
    selectsort(name,N);
    
    printf("按字典输出名单:\n");
    for(i=0;i<N;i++)
        printf("%s\n",name[i]);
        
    return 0;
} 

void selectsort(char str[][20],int n){
    int i,j,k,sign;
    char temp[20];
    for(i=0;i<n-1;i++){
        k=i;
        for(j=i+1;j<n;j++){
            sign=strcmp(str[k],str[j]);
            
            if(sign>0)
                k=j;
        }
        if(k!=i){
            strcpy(temp,str[i]);
            strcpy(str[i],str[k]);
            strcpy(str[k],temp);
        }
    }
}

 

 4.

#include <stdio.h>

int main()
{
    int n;
    int *pn;

    n = 42;
    pn = &n;

    printf("%#x: %d\n", &n, n);
    printf("%#x: %#x\n", &pn, pn);
    printf("%d\n", *pn);

    return 0;
}

 

 (1)整型变量n的地址是0x62fe1c,存放的是整形数据42

(2)指针变量pn的地址是0x62fe10,存放的是变量n的地址

(3)通过*pn间接访问的是变量n里存放的数据

 

5.

#include <stdio.h>

#define N 5

int main()
{
    int a[N] = {1, 9, 2, 0, 7};
    int i;
    int *p;

    for(i=0; i<N; ++i)
        printf("&a[%d] = %#x,  a[%d] = %d\n", i, &a[i], i, a[i]);
    
    printf("\n");

    for(i=0; i<N; ++i)
        printf("a+%d = %#x,  *(a+%d) = %d\n", i, a+i, i, *(a+i));
    
    printf("\n");

    p = a;
    for(i=0; i<N; ++i)
        printf("p+%d = %#x,  *(p+%d) = %d\n", i, p+i, i, *(p+i));
     
    return 0;
}

 

 (1)都可以

(2)都可以

 

总结

1.学习了二分查找、选择排序的想法和算法

2.理解了指针的概念,通过指针间接访问变量、数组元素,*p是访问那个地址里的数据,p是地址

3.学习使用了strcmp strcpy,在字符型数组里注意与数据型不同的运用

 

posted @ 2021-12-09 10:16  gfygfy  阅读(51)  评论(0)    收藏  举报