Java面向对象编程

2023-09-18 08:43:39

主机甲和乙已建立了TCP连接,甲始终以MSS=1KB大小的段发送数据,并一直有数据发送;乙每收到一个数据段都会发出一个接收窗口为10KB的确认段。若甲在t时刻发生超时时拥塞窗口为8KB,则从t时刻起,不再发生超时的情况下,经过10个RTT后,甲的发送窗口是()

A.10KB

B.12KB

C.14KB

D.15KB

答案:A

某主机的IP 地址为 180.80.77.55,子网掩码为 255.255.252.0。若该主机向其所在子网发送广播分组,则目的地址可以是()

A.180.80.76.0

B.180.80.76.255

C.180.80.77.255

D.180.80.79.255

答案:D

ARP 协议的功能是()

A.根据 IP 地址查询 MAC 地址

B.根据 MAC 地址查询 IP 地址

C.根据域名查询 IP 地址

D.根据 IP 地址查询域名

答案:A

下列关于IP 路由器功能的描述中,正确的是()
Ⅰ. 运行路由协议,设置路由表
Ⅱ. 监测到拥塞时,合理丢弃 IP 分组
Ⅲ. 对收到的 IP 分组头进行差错校验,确保传输的 IP 分组不丢失
Ⅳ、 根据收到的 IP 分组的目的 IP 地址,将其转发到合适的输出线路上

A.仅Ⅲ、 Ⅳ

B.仅Ⅰ、 Ⅱ、 Ⅲ

C.仅Ⅰ、 Ⅱ、 Ⅳ

D.Ⅰ、 Ⅱ、 Ⅲ、 Ⅳ

答案:C

以太网的MAC 协议提供的是()

A.无连接不可靠服务

B.无连接可靠服务

C.有连接不可靠服务

D.有连接可靠服务

答案:A

在TCP/IP体系结构中,直接为 ICMP 提供服务的协议是()

A.PPP

B.IP

C.UDP

D.TCP

答案:B

主机甲向主机乙发送一个(SYN=1, seq=11220)的 TCP 段,期望与主机乙建立 TCP 连接,若主机乙接受该连接请求,则主机乙向主机甲发送的正确的 TCP 段可能是()

A.( SYN=0, ACK=0, seq=11221, ack=11221)

B.( SYN=1, ACK=1, seq=11220, ack=11220)

C.( SYN=1, ACK=1, seq=11221, ack=11221)

D.( SYN=0, ACK=0, seq=11220, ack=11220)

答案:C

TCP/IP 参考模型的网络层提供的是()

A.无连接不可靠的数据报服务

B.无连接可靠的数据报服务

C.有连接不可靠的虚电路服务

D.有连接可靠的虚电路服务

答案:A

主机甲和主机乙之间建立一个TCP连接,TCP最大段长度为1000字节,若主机甲的当前拥塞窗口为4000字节,在主机甲向主机乙连续发送 两 个最大段后,成功收到主机乙发送的第一 个 段的确认段,确认段中通告的 接收 窗口大小为2000字节,则此时主机甲还可以向主机乙发送的最大字节数是()

A.1000

B.2000

C.3000

D.4000

答案:A

某网络的IP地址空间为192.168.5.0/24 , 采用定长子网划分,子网掩码为255.255.255.248,则该网络的最大子网个数 、每个子网内的最大可分配地址个数()

A.32,8

B.32,6

C.8,32

D.8,30

答案:B

五子棋
题目描述: NowCoder最近爱上了五子棋,现在给你一个棋局,请你帮忙判断其中有没有五子连珠(超过五颗也算)。
输入描述:输入有多组数据,每组数据为一张20x20的棋盘。
其中黑子用“*"表示,白子用“+"表示,空白位置用“∵"表示。
输出描述:如果棋盘上存在五子连珠(无论哪种颜色的棋子),输入"Yes”,否则输出"No”。

public class Main66 {

    //五子棋

    final public static int N=20;

    public static int count(String[] table,int x,int y,char ch){

        //(i,j)位置的4个大方向取检测,统计相同颜色棋子的最大个数

        int[][][] direct={

                {{0,-1},{0,1}}, //横向: 左 右

                {{-1,0},{1,0}}, //竖向: 上 下

                {{-1,-1},{1,1}}, //左上到右下: 左上 右下

                {{-1,1},{1,-1}}, //有伤到左下: 右上 左下

        };



        int result=0;

        for (int i = 0; i < 4; ++i) {

            //统计单个方向相同的棋子的个数

            int c=0;

            for (int j = 0; j < 2; ++j) {

                //将一个大方向分成两个小方向来进行遍历

                int nx=x;

                int ny=y;

                //超一个方向去统计相同颜色棋子的个数

                while (nx >=0 && nx <N && ny>=0 && ny<N &&  
table[nx].charAt(ny)  ==ch){

                    c++;

                    nx=nx+direct[i][j][0];

                    ny=ny+direct[i][j][1];

                }

            }

            result = c > result ? c : result;

        }

        return result-1;

    }



    public static boolean sover(String[] table){

        //对棋谱中的每个位置进行检测,如果该位置是棋子,就统计该棋子周围是否存在五子连珠

        for (int i = 0; i < N; ++i) {

            for (int j = 0; j < N; ++j) {

                if (table[i].charAt(j) =='*' ||table[i].charAt(j)=='+'){

                    //(i,j)位置的4个大方向取检测,统计相同颜色棋子的最大个数

                    if (count(table,i,j,table[i].charAt(j)) >=5){

                        return true;

                    }



                }

            }

        }

        return false;

    }

    public static void main(String[] args) {

        Scanner scanner=new Scanner(System.in);

        while (scanner.hasNext()){

            //接收棋谱

            String[] table=new String[N];

            for (int i = 0; i < N; ++i) {

                table[i]=scanner.next();

            }

            //统计是否存在连珠五子棋

            System.out.println(sover(table)?"Yes" :"No");

        }

    }

}
Emacs计算器
题目描述: Emacs号称神的编辑器,它自带了一个计算器。与其他计算器不同,它是基于后缀表达式的,即运算符在操作数的后面。例如23+等价于中缀表达式的"2+ 3”"。
请你实现一个后缀表达式的计算器。
输入描述:输入包含多组数据。
每组数据包括两行:第一行是一个正整数n(3Sn<50);紧接着第二行包含n个由数值和运算符组成的列表。
“+-*/"分别为加减乘除四则运算,其中除法为整除,即“5/3=1”。
输出描述:对应每一组数据,输出它们的运算结果。

 

public class Main67 {

    //Emacs计算器

    public static void main(String[] args) {

        Scanner scanner=new Scanner(System.in);

        while (scanner.hasNext()){

            int n=scanner.nextInt();

            String str;

            Stack<Integer> s = new Stack<>();

            for (int i = 0; i < n; ++i) {

                str=scanner.next();

                char ch=str.charAt(0);

                if (ch>='0' && ch<='9'){

                    //遇到数字

                    s.add(Integer.parseInt(str));

                }else {

                    //运算符

                    int right=s.pop();

                    int left=s.pop();



                    switch (ch){

                        case '+':

                            s.add(left+right);

                            break;

                        case '-':

                            s.add(left-right);

                            break;

                        case '*':

                            s.add(left*right);

                            break;

                        case '/':

                            s.add(left/right);

                            break;

                    }

                }

            }

            System.out.println(s.pop());

        }

    }

}
更多推荐

【1++的C++进阶】之C++11(二)

👍作者主页:进击的1++🤩专栏链接:【1++的C++进阶】文章目录一,类的新变化二,可变参数模板三,lambda表达式一,类的新变化在C++03之前,我们的默认成员函数有6个,我们在类与对象这篇中有过详细的讲解。C++11中又增加了两个默认成员函数—移动构造与移动赋值重载,其底层原理以及优势我们在上节已经有过描述。

在本地搭建WAMP服务器并通过端口实现局域网访问(无需公网IP)

文章目录前言1.Wamp服务器搭建1.1Wamp下载和安装1.2Wamp网页测试2.Cpolar内网穿透的安装和注册2.1本地网页发布2.2Cpolar云端设置2.3Cpolar本地设置3.公网访问测试4.结语前言软件技术的发展日新月异,各种能方便我们生活、工作和娱乐的新软件层出不穷,但也有一些经过时间和用户考验的老牌

服务器基准测试实践:SysBench的搭建与基本使用

🏆作者简介,黑夜开发者,CSDN领军人物,全栈领域优质创作者✌,CSDN博客专家,阿里云社区专家博主,2023年6月CSDN上海赛道top4。🏆数年电商行业从业经验,AWS/阿里云资深使用用户,历任核心研发工程师,项目技术负责人。🎉欢迎👍点赞✍评论⭐收藏文章目录🚀一、SysBench是什么?🚀二、SysBe

VSCode 安装使用教程 环境安装配置 保姆级教程

一个好用的IDE不仅能提升我们的开发效率,还能让我们保持愉悦的心情,这样才是非常Nice的状态^_^那么,什么是IDE呢?whatIDE(IntegratedDevelopmentEnvironment,集成开发环境)是含代码编辑器、关键词高亮、智能感应、智能纠错、格式美化、版本管理等功能于一身的"高级代码编辑器"每个

MySQL(4)索引实践(2)

一、分页优化limit100010,其实不是只查询出10条记录,mysql底层会查询出1100条,然后舍去前1000条所以,随着页的增多,查询效率会降低1、可以使用取范围的方式比如id>1000方式优化2、使用关联查询优化,子表使用覆盖索引,不用查出来所有数据,主表关联子表查询出数据二、关联表执行过程(1)两种算法1、

Keepalived

这里写目录标题Keepalived一、Keepalived相关知识点概述1.单服务的风险(单点故障问题)2.一个合格的集群应该具备的特性3.VRRP虚拟路由冗余协议4.健康检查5.脑裂二.keepalive1.Keepalived介绍2.Keepalived体系主要模块及其作用3.keepalived原理4.keepa

大数据-离线项目

第一章需求分析需求分析与设计项目需求背景"某APP上线后经营得当使用户日活量增多出现以下问题""营销分析断层:"市场营销成本居高不下,投放拉新的效果追踪出现断层,无法追踪各渠道实际转化率,难以准确分析ROI。"产品迭代无法量化:"缺少实时的用户行为分析能力,使产品功能不知道怎么改改好了也不知道效果怎么样"用户运营不精准

jenkins中添加sonnarqube与OWASP Dependency-Check

jenkinsjenkins离线插件地址:http://updates.jenkins-ci.org/download/pluginshttps://updates.jenkins.io/download/pluginshttps://mirrors.tuna.tsinghua.edu.cn/jenkins/plugi

io流笔记

字节输出流1.创建字节输出流对象FileOutputStream变量名=newFileOutputStream(name:);①参数是字符串表示的路径或者是file对象都是可以的②如果文件不存在会创造一个新的文件,但是要保证父级路径是存在的。③如果文件已经存在,则会清空文件2.写数据write(intb)一次写一个字节

想要通过软件测试的面试,都需要学习哪些知识

很多人认为,软件测试是一个简单的职位,职业生涯走向也不会太好,但是随着时间的推移,软件测试行业的变化,人们开始对软件测试行业的认知有了新的高度,越来越多的人开始关注这个行业,开始重视这个职位,那么,软件测试知识到底需要学到怎么样的成都,才能够轻松通过面试,在工作中游刃有余呢?第一、测试理论首先需要对测试岗位有一定的了解

贝叶斯分位数回归、lasso和自适应lasso贝叶斯分位数回归分析免疫球蛋白、前列腺癌数据...

原文链接:http://tecdat.cn/?p=22702贝叶斯回归分位数在最近的文献中受到广泛关注,本文实现了贝叶斯系数估计和回归分位数(RQ)中的变量选择,带有lasso和自适应lasso惩罚的贝叶斯(点击文末“阅读原文”获取完整代码数据)。摘要还包括总结结果、绘制路径图、后验直方图、自相关图和绘制分位数图的进一

热文推荐