华中科技大学_2010___考研计算机_复试上机

本文介绍了一种实现奇偶校验的方法,通过将字符转换为二进制并进行校验来确保数据的准确性。此外,还提供了一个能够处理大数加法的算法,该算法能够处理超过常规整数范围的数值相加。

1,奇偶校验

题目描述:

输入一个字符串,然后对每个字符进行奇校验,最后输出校验后的二进制数(如'3’,输出:10110011)。

输入:

输入包括一个字符串,字符串长度不超过100。

输出:

可能有多组测试数据,对于每组数据,
对于字符串中的每一个字符,输出按题目进行奇偶校验后的数,每个字符校验的结果占一行。

样例输入:
3
3a
样例输出:
10110011
10110011
01100001

总结:感觉还好,但是下面再贴出一份代码,网上找的,感觉非常有意思,直接使用异或运算就行。

#include<iostream>
#include<string>
using namespace std;

void odd_verify(char a){
	int num[8]={0,0,0,0,0,0,0,0};
	int i=0,j=0;
	
	while(a){
		if(a%2 == 1) j++;
		num[i++] = a%2;
		a=a>>1;
	}

	if(j%2 != 1){
		num[7] = 1;
	}

	for(j=7;j>0;j--){
		cout<<num[j];
	}
	cout<<num[0]<<endl;
}

int main(){
	string str;
	int i,len;

	while(cin>>str){
		len=str.length();
		for(i=0;i<len;i++){
			odd_verify(str[i]);
		}
	}
	
	
	return 0;
}


#include<stdio.h>
#include<string.h>

int main()
{
    char str[110];
    while(~scanf("%s",&str))
    {
       
       for(int i=0;str[i];i++)
       {
          int num[8];
          memset(num,0,sizeof(num));//注意memset所处的位置 
          int j=0;
          while(str[i])
          {
            num[j++]=str[i]%2;
            str[i]=str[i]/2;
          }
          num[7]=num[7]^num[6]^num[5]^num[4]^num[3]^num[2]^num[1]^num[0]^1;//异或运算符^ 
          for(int j=7;j>=0;j--)
             if(j==0)printf("%d\n",num[j]);
             else printf("%d",num[j]);
       }
    }  
    return 0;  
}


2,加法器

题目描述:

实现一个加法器,使其能够输出a+b的值。

输入:

输入包括两个数a和b,其中a和b的位数不超过1000位。

输出:

可能有多组测试数据,对于每组数据,
输出a+b的值。

样例输入:
2 6
10000000000000000000 10000000000000000000000000000000
样例输出:
8
10000000000010000000000000000000

总结:写的不好,实现了。

#include<iostream>
#include<string>
using namespace std;
#define max_n 1020

int main(){
	string str1,str2;
	int i,j,s,jin;
	int len1,len2;

	while(cin>>str1 && cin>>str2){
		int num1[max_n] = {0};
		int num2[max_n] = {0};
		int sum[max_n] = {0};

		len1 = str1.length();
		len2 = str2.length();
		j=0;
		for(i=len1-1;i>=0;i--){
			num1[j++] = str1[i] - '0';
		}
		j=0;
		for(i=len2-1;i>=0;i--){
			num2[j++] = str2[i] - '0';
		}
		
		jin=0;
		for(i=0;i<max_n;i++){
			s=num1[i] + num2[i] + jin;
			sum[i] = s % 10;
			jin = s / 10;
		}
		
		for(i=max_n - 1;i>=0;i--){
			if(i != 0){
				if(sum[i] != 0){
					for(j = i;j >= 0;j--){
					cout<<sum[j];
					}
					break;
				}
			}else{
				cout<<sum[0];
			}
		}
		cout<<endl;

	}

	return 0;
}






标题基于SpringBoot的马术俱乐部管理系统设计与实现AI更换标题第1章引言介绍马术俱乐部管理系统的研究背景、意义、国内外研究现状、论文方法及创新点。1.1研究背景与意义阐述马术俱乐部管理系统对提升俱乐部管理效率的重要性。1.2国内外研究现状分析国内外马术俱乐部管理系统的发展现状及存在的问题。1.3研究方法以及创新点概述本文采用的研究方法,包括SpringBoot框架的应用,以及系统的创新点。第2章相关理论总结和评述与马术俱乐部管理系统相关的现有理论。2.1SpringBoot框架理论介绍SpringBoot框架的基本原理、特点及其在Web开发中的应用。2.2数据库设计理论阐述数据库设计的基本原则、方法以及在管理系统中的应用。2.3马术俱乐部管理理论概述马术俱乐部管理的基本理论,包括会员管理、课程安排等。第3章系统设计详细描述马术俱乐部管理系统的设计方案,包括架构设计、功能模块设计等。3.1系统架构设计给出系统的整体架构,包括前端、后端和数据库的交互方式。3.2功能模块设计详细介绍系统的各个功能模块,如会员管理、课程管理、预约管理等。3.3数据库设计阐述数据库的设计方案,包括表结构、字段设计以及数据关系。第4章系统实现介绍马术俱乐部管理系统的实现过程,包括开发环境、编码实现等。4.1开发环境搭建介绍系统开发所需的环境,包括操作系统、开发工具等。4.2编码实现详细介绍系统各个功能模块的编码实现过程。4.3系统测试与调试阐述系统的测试方法、测试用例以及调试过程。第5章系统应用与分析呈现马术俱乐部管理系统的应用效果,并进行性能分析。5.1系统应用情况介绍系统在马术俱乐部中的实际应用情况。5.2系统性能分析从响应时间、并发处理能力等方面对系统性能进行分析。5.3用户反馈与改进收集用户反馈,提出系统改进建议。第6章结论与展望总结马术俱乐部管理系统的设计与实现成果,并展望未来的研究
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值