假期作业 6

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       。

A、2.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.表达式 !x 等价于      A       。

A、x==0       B、x==1         C、x != 0       D、x != 1

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

  1. float f, *pf=f; B、float f, *pf=&f; C、float *pf=&f, f; D、float 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    

A、p          B、*p           C、x         D、*&x

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

A、s+1     B、 s++      C、&s[0]+1      D、  &s[1]

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

  #inlcude <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 

15.以下程序的输出结果是     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 

16.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]

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

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

18.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

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

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

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

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

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

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

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

22.以下对二维数组a的正确说明是      B     

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

23.以下程序的输出结果是      C     

void main()

{  int a=5,*p1,**p2;

   p1=&a,p2=&p1;

   (*p1)++;

   printf("%d\n",**p2); 

}

A、5    B、4    C、6    D、不确定

24.设有定义“int a=3,b,*p=&a;”,则下列语句中使b不为3的语句是      B     

 A、b=*&a;   B、b=*a;   C、b=a;   D、b=*p;

25.int main(int argc, char *argv[])

{

    int i, n = 0;

    for (i=1; i<argc; i++) { n = 10*n + *argv[i] – ‘0’; }

    printf(“%d\n”, n);

}

./aout  12  345  678

输出结果为___B______。

A、123  B、136  C、678  D、58

26.已知两个升序数组ab及空数组c:

Int a[] = {1,3,5,7,9,11,13,15,17,19};

Int b[] = {2,4,6,8,10,12,14,16,18,20};

Int c[20];

编写程序将两个数组完成归并,并存入数组c中;

代码:

#include<stdio.h>
#include<string.h>
int main(int argc, const char *argv[])
{
    int a[] = {1,3,5,7,9,11,13,15,17,19};
    int b[] = {2,4,6,8,10,12,14,16,18,20};
    int c[20];
    int m,n,i=0,j=0,k=0;
    m=sizeof(a)/sizeof(int);
    n=sizeof(b)/sizeof(int);

    while(i<m && j<n)
    {
        if(a[i]<b[j])
        {
            c[k]=a[i];
            i++;
            k++;
        }
        else
        {
            c[k]=b[j];
            j++;
            k++;
        }
    }
    if(i==m)
    {
        while(j<n)
        {
            c[k]=b[j];
            j++;
            k++;
        }
    }
    else if(j==n)
    {
        while(i<m)
        {
            c[k]=a[i];
            i++;
            k++;
        }
    }

    for(k=0;k<20;k++)
    {
        printf("%d ",c[k]);
    }
    printf("\n");
    return 0;
}

       

27.编写strcat函数(不调用C的字符串库函数,编写函数 strcat).

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

strDest是目的字符串,strSrc是源串。

代码:

char *strcat(char *strDest, const char *strSrc)

{

        char *temp = strDest;

        while (*strDest)

        {

                strDest++;

        }

        while (*strSrc)

        {

                *strDest = *strSrc;

                strDest++;

                strSrc++;

        }

         *strDest = '\0';

        return temp;

}

28.一个岔路口分别通向诚实国和说谎国。来了两个人,已知一个是诚实国的,另一个是说谎国的。诚实国永远说实话,说谎国永远说谎话。现在你要去说谎国,但不知道应该走哪条路,需要问这两个人。请问应该怎么问?

假设说谎国方位为a,诚实国为b。这时候可以这样问,问其中的一个人,“请问如果我问另一个人,去诚实国的路是哪条,他会怎样回答?”。

此时,得到的答案就是去往说谎国的方向的。

当你问诚实的人的时候,他的答案是“他会说诚实国在a";

当你问说谎者的时候,他的答案是"他会说诚实国在a”。

29.从键盘输入一个十个元素的数组,通过选择排序进行降序排列并输出结果

代码:

#include <stdio.h>
#include <string.h>
#define N  10
int main(int argc, const char *argv[])
{
    int arr[N] = {0};
    int i,j,index,temp;
    for(i=0;i<10;i++)
    {
    scanf("%d",&arr[i]);    
    }        
    for(i=0;i<N;i++)
    {
        index = i;
        for(j =i+1;j<N;j++)
        {
            if(arr[j] > arr[index])
            {
                index = j;
            }
        }
        temp = arr[i];
        arr[i] = arr[index];
        arr[index] = temp;
    }
    for(i=0;i<N;i++)
    {
        printf("%d\t",arr[i]);
    }
    printf("\n");
    return 0;
}

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

代码:

#include<stdio.h>
#include<string.h>
#define N 32
int swap(char *head, char *tail)
{
    while(head < tail)
    {
        *head ^= *tail;
        *tail ^= *head;
        *head ++ ^= *tail--;
    }
}
int main(int argc, const char *argv[])
{
    char buff[N] = "I love china";
    char *head = buff, *tail = buff;
    puts(buff);
    while('\0' != *tail)
    tail ++;
    swap(buff, tail - 1);
    while('\0' != *head)
    {    
        while(32 == *head)
        head++;    
        tail = head;
        while(32 != *tail && '\0' != *tail)
        tail++;
        swap(head,tail - 1);
        head = tail;
    }
    puts(buff);
    return 0;
}

31.已知数据data,给data的第六个bit位置1,对data的第4个bit位置0

代码:

#include<stdio.h>
#include<string.h>
int main(int argc, const char *argv[])
{
    int data=0;
    printf("input>>");
    scanf("%d",&data);
    getchar();
    int a=data|1<<5;
    int b=a&~(1<<3);
    printf("%d\n",b);
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/459965.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Ubuntu安装SVN服务并结合内网穿透实现公网访问本地存储文件

&#x1f525;博客主页&#xff1a; 小羊失眠啦. &#x1f3a5;系列专栏&#xff1a;《C语言》 《数据结构》 《C》 《Linux》 《Cpolar》 ❤️感谢大家点赞&#x1f44d;收藏⭐评论✍️ 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&…

C语言的循环结构

目录 前言 1.三种循环语句 1.while循环 2.for循环 2.1缺少表达式的情况 3.do while循环 2.break语句和continue语句 2.1在while循环中 2.2在for循环中 2.3在do while 循环中 3.循环的嵌套 4.go to语句 前言 C语⾔是结构化的程序设计语⾔&#xff0c;这⾥的结构指的是…

自然语言处理(NLP)——使用Rasa创建聊天机器人

1 基本概念 1.1 自然语言处理的分类 IR-BOT&#xff1a;检索型问答系统 Task-bot&#xff1a;任务型对话系统 Chitchat-bot:闲聊系统 1.2 任务型对话Task-Bot:task-oriented bot 这张图展示了一个语音对话系统&#xff08;或聊天机器人&#xff09;的基本组成部分和它们之间的…

C# 实现微信自定义分享

目录 需求与调整 代码实现 获取令牌 生成合法票据 获取有效签名 客户端准备 客户端实现 小结 需求与调整 在微信中打开网页应用后&#xff0c;可以选择将地址发送给朋友进行分享&#xff0c;如下图&#xff1a; 在实际的应用中&#xff0c;我们可能不是简单的将该网页…

深度学习的新进展:解析技术演进与应用前景

深度学习的新进展&#xff1a;解析技术演进与应用前景 深度学习&#xff0c;作为人工智能领域的一颗璀璨明珠&#xff0c;一直以来都在不断刷新我们对技术和未来的认知。随着时间的推移&#xff0c;深度学习不断迎来新的进展&#xff0c;这不仅推动了技术的演进&#xff0c;也…

ChatGPT高效提问—prompt常见用法(续篇三)

ChatGPT高效提问—prompt常见用法&#xff08;续篇三&#xff09; 1.1 多选项 ​ 多选项技术为模型提供了一个清晰的问题或任务&#xff0c;并附带一组预先定义的潜在答案。这种方法在生成仅限于特定选项集的文本方面表现出色&#xff0c;适用于问答、文本补全和其他任务。利…

CrystalDiskInfo:一款免费的硬盘健康检测软件

CrystalDiskInfo&#xff1a;一款免费的硬盘健康检测软件&#xff0c;可以显示出硬盘的使用时间、温度、剩余寿命和健康状态等。该软件支持多种语言和多种硬盘类型&#xff0c;使用简单&#xff0c;操作直观。 感觉真正有用的是读取到的硬盘通电时间&#xff0c;其他的估计意义…

[大厂实践] Netflix容器平台内核panic可观察性实践

在某些情况下&#xff0c;K8S节点和Pod会因为出错自动消失&#xff0c;很难追溯原因&#xff0c;其中一种情况就是发生了内核panic。本文介绍了Netflix容器平台针对内核panic所做的可观测性增强&#xff0c;使得发生内核panic的时候&#xff0c;能够导出信息&#xff0c;帮助排…

[当人工智能遇上安全] 11.威胁情报实体识别 (2)基于BiGRU-CRF的中文实体识别万字详解

您或许知道&#xff0c;作者后续分享网络安全的文章会越来越少。但如果您想学习人工智能和安全结合的应用&#xff0c;您就有福利了&#xff0c;作者将重新打造一个《当人工智能遇上安全》系列博客&#xff0c;详细介绍人工智能与安全相关的论文、实践&#xff0c;并分享各种案…

jsp康养小镇管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目

一、源码特点 JSP康养小镇管理系统是一套完善的java web信息管理系统&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为TOMCAT7.0,Myeclipse8.5开发&#xff0c;数据库为Mysql5.0&a…

一文读懂转融通

最近多家公司都在讲解关于转融通要求。今天我们就来详细聊聊&#xff01; 转融通是一种证券借贷机制&#xff0c;它允许机构投资者在融资融券交易中借入或借出证券。 具体来说&#xff0c;机构投资者可以向券商借入证券&#xff0c;或者将持有的证券借给券商&#xff0c;以扩大…

【Spring】Bean 的实例化方式

Spring 为 Bean 提供了多种实例化方式&#xff0c;通常包括4种方式 也就是说在 Spring 中为 Bean 对象的创建准备了多种方案&#xff0c;目的是&#xff1a;更加灵活 第一种&#xff1a;通过构造方法实例化 第二种&#xff1a;通过简单工厂模式实例化 第三种&#xff1a;通过…