1060. Are They Equal (25)-PAT

本文介绍了一种算法,用于判断两个浮点数在一个只保留指定位数有效数字的计算机系统中是否被视为相等。该算法考虑了多种特殊情况,如数字前导零的存在、零的情况及指数计算。

1060. Are They Equal (25)

时间限制
50 ms
内存限制
32000 kB
代码长度限制
16000 B
判题程序
Standard
作者
CHEN, Yue

If a machine can save only 3 significant digits, the float numbers 12300 and 12358.9 are considered equal since they are both saved as 0.123*105 with simple chopping. Now given the number of significant digits on a machine and two float numbers, you are supposed to tell if they are treated equal in that machine.

Input Specification:

Each input file contains one test case which gives three numbers N, A and B, where N (<100) is the number of significant digits, and A and B are the two float numbers to be compared. Each float number is non-negative, no greater than 10100, and that its total digit number is less than 100.

Output Specification:

For each test case, print in a line "YES" if the two numbers are treated equal, and then the number in the standard form "0.d1...dN*10^k" (d1>0 unless the number is 0); or "NO" if they are not treated equal, and then the two numbers in their standard form. All the terms must be separated by a space, with no extra space at the end of a line.

Note: Simple chopping is assumed without rounding.

Sample Input 1:
3 12300 12358.9
Sample Output 1:
YES 0.123*10^5
Sample Input 2:
3 120 128
Sample Output 2:
NO 0.120*10^3 0.128*10^3
推荐指数:※※
来源:http://pat.zju.edu.cn/contests/pat-a-practise/1060
这道题本身并没有复杂的算法,只要考虑好几个case就好了。
1.数的前面有0,例如 5 003 03
2.零的情况,例如 3 0.0000 00.0
3.指数的计算要考虑周全.
#include<iostream>
#include<string.h>
using namespace std;
#define  N 200
int formatstr(char *str,char *sa,int len,int strsize){
	int i;
	int exp_num=0;
	int isbig=0,first_use=0;//first_use is the first use number,because of the case may have such 003 00.03
	for(i=0;i<strsize;i++){//check num is large than 1 or not
		if(str[i]>='1'&&str[i]<='9'){
			first_use=i;
			isbig=1;
			break;
		}
		else if(str[i]=='.'){
			first_use=i;
			isbig=0;
			break;
		}

	}
	int t,is_point_done,has_num;
	if(isbig==1){// num is large than 1
		is_point_done=0;
		for(i=first_use,t=0;t<len;i++){
			if(i<strsize){
				if(str[i]>='0'&&str[i]<='9'){
					sa[t++]=str[i];
					if(0==is_point_done)
						exp_num++;
				}
				else if(str[i]=='.')
					is_point_done=1;
			}else
				sa[t++]='0';
		}
		for(;i<strsize&&is_point_done==0;i++){//check number whether arrive point '.' 
			if(str[i]=='.')
				break;
			exp_num++;
		}
	}
	else{
		has_num=0;
		for(i=first_use+1;i<strsize&&str[i]=='0';i++)//skip 0
			exp_num--;
		for(t=0;t<len;i++){
			if(i<strsize){
				sa[t++]=str[i];
				if(str[i]>='1'&&str[i]<='9')
					has_num=1;
			}
			else
				sa[t++]='0';
		}
		if(0==has_num)//check whether the case of 00.000000
			exp_num=0;
	}
	sa[t]='\0';
	return exp_num;
}
void print_num(char *a,int len,int exp_num){
	int i;
	cout<<"0.";
	for(i=0;i<len;i++)
		cout<<a[i];
	cout<<"*10^"<<exp_num;
}
int main(){
	int i,n,exp_num_a,exp_num_b;
	char a[N],b[N];
	char sa[N],sb[N];
	cin>>n>>a>>b;
	exp_num_a=formatstr(a,sa,n,strlen(a));//format for two number
	exp_num_b=formatstr(b,sb,n,strlen(b));
	if(exp_num_a==exp_num_b){
		for(i=0;i<n;i++){
			if(sa[i]!=sb[i]){
				cout<<"NO ";
				print_num(sa,n,exp_num_a);
				cout<<" ";
				print_num(sb,n,exp_num_b);
				break;		
			}
		}
		if(i==n){
			cout<<"YES ";
			print_num(sa,n,exp_num_a);
		}
	}
	else{
		cout<<"NO ";
		print_num(sa,n,exp_num_a);
		cout<<" ";
		print_num(sb,n,exp_num_b);
	}
	return 0;
}


(c++题解,代码运行时间小于200ms,内存小于64MB,代码不能有注释)It’s time for the company’s annual gala! To reward employees for their hard work over the past year, PAT Company has decided to hold a lucky draw. Each employee receives one or more tickets, each of which has a unique integer printed on it. During the lucky draw, the host will perform one of the following actions: Announce a lucky number x, and the winner is then the smallest number that is greater than or equal to x. Ask a specific employee for all his/her tickets that have already won. Declare that the ticket with a specific number x wins. A ticket can win multiple times. Your job is to help the host determine the outcome of each action. Input Specification: The first line contains a positive integer N (1≤N≤10 5 ), representing the number of tickets. The next N lines each contains two parts separated by a space: an employee ID in the format PAT followed by a six-digit number (e.g., PAT202412) and an integer x (−10 9 ≤x≤10 9 ), representing the number on the ticket. Then the following line contains a positive integer Q (1≤Q≤10 5 ), representing the number of actions. The next Q lines each contain one of the following three actions: 1 x: Declare the ticket with the smallest number that is greater than or equal to x as the winner. 2 y: Ask the employee with ID y all his/her tickets that have already won. 3 x: Declare the ticket with number x as the winner. It is guaranteed that there are no more than 100 actions of the 2nd type (2 y). Output Specification: For actions of type 1 and 3, output the employee ID holding the winning ticket. If no valid ticket exists, output ERROR. For actions of type 2, if the employee ID y does not exist, output ERROR. Otherwise, output all winning ticket numbers held by this employee in the same order of input. If no ticket wins, output an empty line instead. Sample Input: 10 PAT000001 1 PAT000003 5 PAT000002 4 PAT000010 20 PAT000001 2 PAT000008 7 PAT000010 18 PAT000003 -5 PAT102030 -2000 PAT000008 15 11 1 10 2 PAT000008 2 PAT000001 3 -10 1 9999 1 -10 3 2 1 0 3 1 2 PAT000001 3 -2000 Sample Output: PAT000008 15 ERROR ERROR PAT000003 PAT000001 PAT000001 PAT000001 1 2 PAT102030
08-12
### 命令 'ip ip-prefix Employee index 5 deny 10.1.0.0 18 greater-equal 24 less-equal 24' 该命令是在配置一个名为 `Employee` 的 IP 前缀列表。`index 5` 表示这条规则的序列号为 5,前缀列表匹配时会根据序列号从小到大进行匹配[^5]。`deny` 表示拒绝符合条件的路由信息通过。`10.1.0.0 18` 表示基础网段是 `10.1.0.0`,掩码长度为 18 位。`greater-equal 24 less-equal 24` 限定了具体的匹配范围,即掩码长度必须大于等于 24 位且小于等于 24 位。所以,这条命令的作用是拒绝 `10.1.0.0/18` 网段中掩码长度为 24 位的路由信息通过。 ### 命令 'ip ip-prefix Employee index 10 deny 192.168.2.0 24' 此命令同样是配置名为 `Employee` 的 IP 前缀列表,规则序列号为 10。`deny` 表明拒绝符合条件的路由。`192.168.2.0 24` 明确了基础网段是 `192.168.2.0`,掩码长度为 24 位。由于没有指定 `greater-equal` 和 `less-equal`,根据规则可理解为匹配 `192.168.2.0/24` 且掩码长度为 24 位的路由信息,其作用是拒绝该网段的路由信息通过[^4]。 ### 命令 'ip ip-prefix Employee index 15 permit 0.0.0.0 0 less-equal 32' 该命令配置 `Employee` 前缀列表,规则序列号为 15。`permit` 表示允许符合条件的路由信息通过。`0.0.0.0 0` 代表所有的 IP 地址,因为掩码长度为 0 位。`less-equal 32` 表示掩码长度最大为 32 位。所以,这条命令的作用是允许所有 IP 地址(掩码长度范围从 0 到 32 位)的路由信息通过。 ```plaintext # 总结各命令 # 拒绝 10.1.0.0/18 网段中掩码为 24 位的路由 ip ip-prefix Employee index 5 deny 10.1.0.0 18 greater-equal 24 less-equal 24 # 拒绝 192.168.2.0/24 网段的路由 ip ip-prefix Employee index 10 deny 192.168.2.0 24 # 允许所有 IP 地址的路由 ip ip-prefix Employee index 15 permit 0.0.0.0 0 less-equal 32 ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值