早先年考研的主考科目正是【算法与数据结构】,复习得还算可以。也在当时[百度知道]上回答了许多相关问题,现把他们一起汇总整理一下,供读者参考。


【1】

原题目地址:https://zhidao.baidu.com/question/1574956570322831900.html?entry=qb_uhome_tag

题目:

C语言的题目,求大神来看看

小学生算术学习系统。不断的从键盘输入两个整数级一个运算符(+-*/)之一,并输入计算结果。若计算结果正确,则显示“很好,做对了。”负责献世“做错了,再做一次“。系统规定,只能输入三次答案。当第三次输入答案任然错误时,系统将显示正确答案。本系统要求有”是否继续”的提示,用户输入“y”,表示继续,输入“n”表示结束

答:

#include <stdio.h>
#include <time.h>
#include <windows.h>
#include <stdlib.h> int main()
{
int a,b,Suan;
int sum; //用户输入答案
int C; //正确答案
int D; //正确余数
int yu = 0; //输入的余数
int t = 0; //开关变量(求余数)
int i = 3;
int temp = NULL;
char Insert = NULL;
srand(time(NULL)); Q: a = rand()%100;
b = rand()%100;
Suan = rand()%100;
t = 0;
if(Suan <=25)
{
C = a+b;
printf("%d+%d=? :\n",a,b);
temp = 1;
D = 0;
yu = 0;
}
else if(Suan > 26 && Suan <= 50)
{
C = a-b;
printf("%d-%d=? :\n",a,b);
temp = 2;
D = 0;
yu = 0;
}
else if(Suan > 50 && Suan <= 75)
{
C = a*b;
printf("%d*%d=? :\n",a,b);
temp = 3;
D = 0;
yu = 0;
}
else if(Suan > 75 && Suan <= 100)
{
C = a/b;
D = a%b;
t = 1;
printf("%d/%d=? (商):\n",a,b);
temp = 4;
}
A: if(5 == temp)
{
printf("%d+%d=? :\n",a,b);
}
if(6 == temp)
{
printf("%d-%d=? :\n",a,b);
}
if(7 == temp)
{
printf("%d*%d=? :\n",a,b);
}
if(8 == temp)
{
printf("%d/%d=? (商):\n",a,b);
} if(temp <= 4)
{
temp++;
temp++;
temp++;
temp++;
} scanf("%d",&sum);
if(t == 1)
{
printf("余数多少:");
scanf("%d",&yu);
} printf("\n---------------------\n"); if(C == sum && D == yu)
printf("很好,做对了。\n");
else
{
if(1 != i)
{
printf("做错了,再做一次!(你还有%d次机会)\n",i-1);
i--;
goto A;
}
else
{
if(t == 0)
printf("做错了!正确答案是 %d!\n",C);
else
{
printf("做错了!正确答案(商)是 %d!\n",C);
printf("(余数)是 %d!\n",D);
}
//i = 3;
} }
i = 3;
printf("-----------------------------------------------\n");
printf("是否继续<y/n>:\n"); P: scanf("%c",&Insert);
if('y' == Insert)
goto Q;
if('n' == Insert)
exit(-1);
else
{
Insert = NULL;
goto P;
} system("pause");
return 0;
}

【2】

原题目地址:https://zhidao.baidu.com/question/1495135027232307579.html?entry=qb_uhome_tag

题目:

求解c语言指针问题

#include<stdio.h>
#include<conio.h>
#define N 2
#define M 4 double *calculate1(double (*p)[M], double *p1) {
int i, j;
double s=0;
for (j=0; j<M; j++) {
for (i=0; i<N; i++) {
s+=*(*p+j);
p++;
}
for (i=0; i<N; i++) p--;
*(p1+j)=s;
s=0;
}
p1=p1-M;
return p1;
}
void main() {
int m;
double score[N][M]={0, 1, 2, 3, 4, 5, 6, 7}, sbj[M], (*p)[M]=score, *p1=sbj;
p1=calculate1(p, p1);
for (m=0; m<M; m++) printf("\n第%d科总分为%.1lf\n", m+1, *(p1+m));
}

score[N][M]表示N个学生的M门科目的成绩,算出各科的总分

为什么结果是这样

答:

#include<stdio.h>
#include<conio.h>
#include <windows.h>
#define N 2
#define M 4
void calculate(double (*p)[M],double *p1)
{
int i,j;
double s=0;
/*for(i=0;i<N;i++)
{
for(j=0;j<M;j++)
{
printf("%f\t",*(*(p+i)+j));
}
putchar(10);
}*/
for(i=0;i<M;i++)
{
for(j=0;j<N;j++)
{
//printf("%f\t",*(*(p+j)+i));
s+=*(*(p+j)+i);
}
*(p1+i)=s;
s=0;
}
return;
}
int main()
{
int m;
double score[N][M]={0,1,2,3,4,5,6,7},sbj[M],
(*p)[M]=score,*p1=sbj;
calculate(p,p1);
for(m=0;m<M;m++)
printf("\n第%d科总分为%.1lf\n",m+1,*(p1+m)); system("pause");
return 0;
}

我读不懂你的程序,很多都不需要的。你可以参照我写的!有问题可以追问!

【3】

原题目地址:https://zhidao.baidu.com/question/1895405030720891420.html?entry=qb_uhome_tag

题目:

求C语言大神助攻解决这几道问题



答:


/*******/
/***1***/
/*******/
#include<stdio.h>
#include <windows.h> int Judge(char a[],char b[])
{
int i,j;
for(i=0,j=0; a[i]!='\0' ; i++,j++)
{
if(a[i] == b[j])
continue;
if(a[i] > b[j])
return 1;
if(a[i] < b[j])
return -1;
}
return 0;
} int main()
{
int m = NULL;
char str1[5] = "abc";
char str2[5] = "abb";
puts(str1);
putchar(10);
puts(str2);
m = Judge(str1,str2); if(m == 1)
printf("[>]\n");
else if(m == -1)
printf("[<]\n");
else
printf("[=]\n"); system("pause");
return 0;
} ////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////// /*******/
/***2***/
/*******/ #include<stdio.h>
#include <windows.h> int main()
{ float sum = 1.0;
int ss;
int s=1,s1=1;
printf("sum=1/1");
while(1.0/s >= 1e-6)
{
sum += 1.0/s;
printf(" +1/%d",s);
ss = s1;
s1 = s;
s += ss; }
sum += 1.0/s;
printf(" +1/%d",s);
printf(" = %f\n",sum); system("pause");
return 0;
} ////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////// /*******/
/***3***/
/*******/ #include<stdio.h>
#include <windows.h> void Func(int a[][4])
{
int i,j,t = 0;
for(i=0; i<4; i++)
{
for(j=0; j<4; j++)
{
if(a[j][i] > 0)
t++;
}
if(t>=1)
{
printf("%d\n",i);
t = 0;
}
}
return;
} int main()
{
int a[4][4];
int i,j;
for(i=0; i<4; i++)
for(j=0; j<4; j++)
scanf("%d",&a[i][j]); for(i=0; i<4; i++)
{
for(j=0; j<4; j++)
printf("%d\t",a[i][j]);
putchar(10);
} putchar(10);
Func(a); system("pause");
return 0;
} /*******/
/***4***/
/*******/ #include <stdio.h>
#include <windows.h> void Connect(char a[],char b[],char c[])
{
int i,j;
for(i=0; a[i]!='\0'; i++)
c[i] = a[i];
for(j=0; b[j]!='\0'; j++)
c[i++] = b[j];
c[i]='\0';
return;
} int main()
{
int m = NULL;
char str1[5] = "abc";
char str2[10] = "bcde";
char str3[20];
printf("str1=");
puts(str1);
putchar(10);
printf("str2=");
puts(str2);
putchar(10);
Connect(str1,str2,str3);
printf("str3=");
puts(str3); system("pause");
return 0;
} ////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////// /*******/
/***5***/
/*******/ #include<stdio.h>
#include <windows.h> int main()
{
int i;
float sum=0;
double f1=1.0,f2=1.0,t;
printf("sum=");
while(sum<=100.0)
{
sum += f1/f2;
printf(" +%f/%f",f1,f2);
t=f2;
f2=f2+f1;
f1=t;
}
printf("= %.2f\n",sum); system("pause");
return 0;
} ////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////// /*******/
/***6***/
/*******/ #include<stdio.h>
#include <windows.h> void Func(int a[][4])
{
int i,j,t = 0;
for(i=0; i<4; i++)
{
for(j=0; j<4; j++)
{
if(a[i][j] > 0)
t++;
}
if(t>=1)
{
printf("%d\n",i);
t = 0;
}
}
return;
} int main()
{
int a[4][4];
int i,j;
for(i=0; i<4; i++)
for(j=0; j<4; j++)
scanf("%d",&a[i][j]); for(i=0; i<4; i++)
{
for(j=0; j<4; j++)
printf("%d\t",a[i][j]);
putchar(10);
} putchar(10);
Func(a); system("pause");
return 0;
}

请你叫我雷锋,帮你做了这么多题!有问题欢迎追问!

(哈哈,当时心情肯定不错,帮忙做了那么多题目,啊哈哈~)

有关C++程序设计基础的各种考题解答参考汇总的更多相关文章

  1. 内存布局------c++程序设计基础、编程抽象与算法策略

    图中给出了在一个典型c++程序中如何组织内存的框架.程序中的指令(在底层都是按位存储的).全局变量.静态对象和只读常量往往被存储在静态去(static area)(第二个图中的数据段.代码段.值得注意 ...

  2. C语言程序设计基础

    C语言程序设计基础 目录 C语言 C语言基础 C语言编程注意 C语言 C语言基础 C语言编程注意 0<9<9和0<9&&9<9是不同的 数组的声明和定义 con ...

  3. C#程序设计基础——常量

    C#程序设计基础——常量 常量是在编译时已知,并且在程序的生存期内不发生更改的不可变值.常量使用const修饰符进行声明. 常量必须在声明时初始化,且常量的类型必须为以下类型之一:sbyte/byte ...

  4. Oracle数据库之PL/SQL程序设计基础

    PL/SQL程序设计基础 一.PL/SQL块结构 前边我们已经介绍了PL/SQL块的结构,再来回顾一下: DECLARE /* * 声明部分——定义常量.变量.复杂数据类型.游标.用户自定义异常 */ ...

  5. 学而精计算机公共基础学习之路TEST2(程序设计基础)

    程序设计基础 程序设计方法与风格 1.程序设计方法 程序设计: 指设计.编制.调试程序的方法和过程. 程序设计方法是研究问题求解如何进行系统构造的软件方法学.常用的程序设计方法有:结构化程序设计方法. ...

  6. C语言程序设计基础-第1周作业-初步

    1.安装带有计算机术语的翻译软件 2.在自己电脑上安装C编译器,windows系统建议安装dev-c++,其他系统自行查找. 3.加入课程小组,有任何疑问可以在小组中提问:https://group. ...

  7. 谈谈书本《c#物联网程序设计基础》中的技术瑕疵,如果你将要读本书,请进来看看!

    今天去书店看到一本名为<c#物联网程序设计基础>的书,对物联网感兴趣的我抓起来就看,书中的项目都是上位机开发项目,较简单,如果物联网开发只是这样,看起来我做物联网开发也是绰绰有余.这边书我 ...

  8. 【原创 Hadoop&Spark 动手实践 9】Spark SQL 程序设计基础与动手实践(上)

    [原创 Hadoop&Spark 动手实践 9]SparkSQL程序设计基础与动手实践(上) 目标: 1. 理解Spark SQL最基础的原理 2. 可以使用Spark SQL完成一些简单的数 ...

  9. 【原创 Hadoop&Spark 动手实践 10】Spark SQL 程序设计基础与动手实践(下)

    [原创 Hadoop&Spark 动手实践 10]Spark SQL 程序设计基础与动手实践(下) 目标: 1. 深入理解Spark SQL 程序设计的原理 2. 通过简单的命令来验证Spar ...

  10. C语言程序设计基础知识点概括

    C语言程序设计基础知识点概括 C语言程序设计基础知识点1.函数是C语言的基本构成单位.main函数是C语言程序的唯一入口.2.C语言程序开发过程. 编译过程:将以.c或.cpp结尾的源程序文件经过编译 ...

随机推荐

  1. FCM发送测试消息(控制台和postman)

    方法1 在firebase控制台新建通知 点击cloud messaging后点击新建通知 输入标题和内容,点击右边的发送测试消息,注意要在真机接收,模拟器收不到 然后添加测试令牌,测试令牌可以在ap ...

  2. 【C#】【平时作业】习题-10-委托

    什么是委托? C# 中的委托(Delegate)类似于 C 或 C++ 中函数的指针. 委托(Delegate) 是存有对某个方法的引用的一种引用类型变量.引用可在运行时被改变. 委托(Delegat ...

  3. Debian 11 (bullseye) 国内软件源

      本文整理了Debian 11在国内的几个软件源. 1.使用说明 一般情况下,将/etc/apt/sources.list文件中Debian默认的软件仓库地址和安全更新仓库地址修改为国内的镜像地址即 ...

  4. 解决docker 容器设置中文语言包出现的问题_docker

    https://www.anquanclub.cn/5821.html 这篇文章主要介绍了解决docker 容器设置中文语言包出现的问题,具有很好的参考价值,希望对大家有所帮助.一起跟随小编过来看看吧 ...

  5. 性能优化!突破性能瓶颈的尖兵CPU Cache

    大家好,我是呼噜噜,今天我们来介绍计算机的储存器之一,CPU高速缓冲存储器也叫高速缓存,CPU Cache 缓存这个专业术语,在计算机世界中是经常使用到的.它并不是CPU所独有的,比如cdn缓存网站信 ...

  6. Qt编写linux上视频流播放器(支持海康大华宇视等各种网络摄像机)

    一.前言 在windows上的视频流播放器有很多,而且各个监控厂家无论大厂还是小厂,基本上都提供了客户端,甚至很多第三方的监控平台软件厂商,也都提供了windows的版本,基本的都没有提供linux版 ...

  7. Qt数据库应用19-图片转pdf

    一.前言 用户的需求真的是千奇百怪,刚做完不同页面横向纵向排版的需求,又来个需要图片转pdf的需求,提供静态函数直接使用. 经过这么些年的社会的毒打,我的原则是:用户是上帝和大爷,尽量站在用户的角度换 ...

  8. Qt编写安防视频监控系统22-摄像机搜索

    一.前言 摄像机搜索模块是后面新增加的,这个模块很有必要,一开始做视频监控系统的时候,那时候还没有研究出来一套纯Qt底层通信的onvif类,也就前几个月搞出来了,支持搜索设备信息和云台控制,所以马上加 ...

  9. CentOS安装tigerVNC Server

  10. 巧用VTable打造炫酷金字塔图表

    在数据分析和可视化领域,表格是展示数据直观.有效的方式之一.今天,就让我们来探索如何利用VTable这个强大的表格组件,制作出既美观又富有信息量的金字塔图表,以及深入了解VTable中各种单元格类型的 ...