专业课真题复习(2019)

简介: 专业课真题复习(2019)

1.题目描述:

编写一个判断素数的函数,在主函数中输入一个整数,输出是否是素数的信息。

#include<stdio.h>
int isprime(int n)
{
  int i;
  for(i=2;i<=n/2;i++)
  {
    if(n%i==0)
    {
      return 0;
    }
  }
  return 1;
}
int main(void)
{
  int number;
  printf("请输入一个整数:\n");
  scanf("%d",&number);
  if(isprime(number))
  {
    printf("该数是一个素数,"); 
  }else{
    printf("该数不是一个素数");
  }
  return 0;
}

2.题目描述:

编写函数dayInMonth(int y,int m)方法。函数的功能是计算y年m月份包含的天数。

#include<stdio.h>
int dayInMonth(int y,int m)
{
  int monthtab[12]={31,28,31,30,31,30,31,31,30,31,30,31};
  if((y%4==0)||(y%100!=0&&y%4==0))
  {
    if(m==2)
    {
      return 29;
    }
  }
  return monthtab[m-1];
 } 
 int main(void)
 {
  int year,month;
  printf("请分别输入年月:\n");
  scanf("%d%d",&year,&month);
  printf("包含的天数为%d",dayInMonth(year,month));
  return 0;
 }

3.题目描述:

13个人围成一圈,从第一个人开始顺序报号1,2,3。凡报到3者推出圈子。找出最后留在圈子中的人原来的序号。要求用链表处理。

#include<stdio.h>
struct people
{
  int no;
  int next;
}peoples[13];
int main()
{
  int i,j,count;
  int number=13;
  for(i=0;i<13;i++)
  {
    peoples[i].no=i+1;
    peoples[i].next=i+1;
    if(i==12)
    {
      peoples[i].next=0;
    }
   } 
   i=0;
   count=0;
   while(number>1)
   {
    printf("number=%d\n",number);
    if(peoples[i].no!=0)
    {
      count++;
      if(count==3)
      {
        peoples[i].no=0;
        number--;
        count=0;
       }
     }
     i=peoples[i].next;
   }
   for(i=0;i<13;i++)
   {
    printf("%d",peoples[i].no);
    if(peoples[i].no!=0)
    {
      printf("最后剩下的人的序号为%d",peoples[i].no);
     }
   }
   return 0;
}

注意:1.书上给的是用静态链表做的,其他地方都是动态链表。

2. 指导最后一个的时候让他再指向头指针。


4.题目描述:

假设文件data.txt中一次读入各行文本,并把各行的文本的字符次序颠倒一下,即在原来k位置上的字符将出现在n-k+1的位置上,其中n是该行文本的长度(不包含最后的回车换行符或文件结束符),最后依次把各行颠倒了字符次序的文本保存到文件result.txt中。

#include<stdio.h>
#include<stdlib.h>
#include<string.h>
void reverse(char *str)
{
  int end=strlen(str)-1;
  int start=0;
  char temp;
  while(start<=end)
  {
    temp=str[end];
    str[end]=str[start];
    str[start]=temp;
    start++;
    end--;
  }
}
int main(void)
{
  FILE *fd;
  FILE *fr;
  char arr[1000];
  int n;
  int len=0;
  if((fd=fopen("data.txt","r"))==NULL)
  {
    printf("can not open this file.");
    exit(0);
  }
  if((fr=fopen("result.txt","w"))==NULL)
  {
    printf("can not open this file.");
    exit(0);
  }
  while(!feof(fd))
  {
    fgets(arr,1000,fd);
    n=strlen(arr);
    if(arr[n-1]=='\n')
    {
      n-=1;
    }
  int end=n-1;
  int start=0;
  char temp;
  while(start<=end)
  {
    temp=arr[end];
    arr[end]=arr[start];
    arr[start]=temp;
    start++;
    end--;
  }
    fprintf(fr,"%s",arr);
  }
  fclose(fd);
  fclose(fr);
  return 0;
}

注意:

1.题目中的条件是若干行,所以不能直接给出行数,但是fscanf()函数把空格也当成了文件结束的标志,教材中给出了这个思考问题。

2.要用feof()函数判断是不是文件末尾,每次都读出1000个字符,当遇到回车的时候,长度要-1.

strlen包括换行符,不包括结束符。

目录
打赏
0
0
0
0
75
分享
相关文章
GitHub Copilot Enterprise登场,或将掀起编程界的ChatGPT革命!
【2月更文挑战第13天】GitHub Copilot Enterprise登场,或将掀起编程界的ChatGPT革命!
222 2
GitHub Copilot Enterprise登场,或将掀起编程界的ChatGPT革命!
TypeScript:数组类型&函数使用&内置对象
本文介绍了 TypeScript 中的数组类型、对象数组、二维数组、函数、函数重载、内置对象等概念,并通过代码示例详细展示了它们的使用方法。还提供了一个使用 HTML5 Canvas 实现的下雨效果的小案例。
162 1
警惕网络背后的陷阱:揭秘DNS缓存中毒如何悄然改变你的网络走向
【8月更文挑战第26天】DNS缓存中毒是一种网络攻击,通过篡改DNS服务器缓存,将用户重定向到恶意站点。攻击者利用伪造响应、事务ID猜测及中间人攻击等方式实施。这可能导致隐私泄露和恶意软件传播。防范措施包括使用DNSSEC、限制响应来源、定期清理缓存以及加强监控。了解这些有助于保护网络安全。
322 1
动态背景,视觉盛宴:JavaScript动画让网页活起来!
动态背景,视觉盛宴:JavaScript动画让网页活起来!
基于springboot+vue.js+uniapp的校园二手交易平台附带文章源码部署视频讲解等
基于springboot+vue.js+uniapp的校园二手交易平台附带文章源码部署视频讲解等
176 2
使用`http.server`模块搭建简单HTTP服务器
使用`http.server`模块搭建简单HTTP服务器
最受欢迎的云主机推荐
本文介绍什么是云主机以及云主机的优势(性价比高、弹性可扩展、安全隔离高、多操作系统支持),然后提供了选择云主机的选购指南(名气大、口碑好、价格适中),最后推荐了几款备受欢迎的云主机。
227 0
最受欢迎的云主机推荐
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问