专业课真题复习(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包括换行符,不包括结束符。

相关文章
|
19天前
|
测试技术
蓝桥杯刷题|01入门真题
蓝桥杯刷题|01入门真题
|
19天前
|
测试技术
蓝桥杯刷题|03入门真题
蓝桥杯刷题|03入门真题
|
19天前
|
测试技术
蓝桥杯刷题|02入门真题
蓝桥杯刷题|02入门真题
|
2月前
|
存储 安全 Java
复习总结01110
复习总结01110
13 0
|
3月前
|
存储 网络协议 测试技术
复习软考之精读真题题解,猜猜这是哪年的真题吧
复习软考之精读真题题解,猜猜这是哪年的真题吧
15 0
|
4月前
|
缓存 前端开发 JavaScript
【面试题】2022前端面试真题
【面试题】2022前端面试真题
|
安全 测试技术 Python
软件测试面试题及答案,这个题库有3千多道最新面试真题可以刷
相信对于很多软件测试新手来说,技术项目的面试是十分让人头疼的,生怕没回答得好,就会跟这个offer失之交臂
149 0
专业课真题复习(2018)
专业课真题复习(2018)
69 0
专业课真题复习(2017)
专业课真题复习(2017)
59 0
专业课真题复习(2021)
专业课真题复习(2021)
93 0