PAT乙级(Basic Level)1002(C++)

本篇博客介绍了一个简单的程序设计问题:读入一个自然数n,计算其各位数字之和,并用汉语拼音的形式输出该和的每一位数字。提供了完整的C++实现代码,包括如何读取数字、计算数字之和及将数字转换为对应汉语拼音的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1002. 写出这个数 (20)

读入一个自然数n,计算其各位数字之和,用汉语拼音写出和的每一位数字。

输入格式:每个测试输入包含1个测试用例,即给出自然数n的值。这里保证n小于10100

输出格式:在一行内输出n的各位数字之和的每一位,拼音数字间有1 空格,但一行中最后一个拼音数字后没有空格。

输入样例:
1234567890987654321123456789
输出样例:
yi san wu
#include<iostream>
using namespace std;
int main(){
	int n,a;
	cin>>n;
	int sum=0;
	while(n){//计算数字各位之和 
		sum=sum+n%10;
		n=n/10;
	}
	if(a>10){
	    sum=sum/10;
	    a=sum;
    if(a>10){
      a=a/10;	
	}
	switch(a){
		case 1:
			cout<<"yi ";
			break;
		case 2:
			cout<<"er ";
			break;
		case 3:
			cout<<"san ";
			break;
		case 4:
			cout<<"si ";
			break;
		case 5:
			cout<<"wu ";
			break;
		case 6:
			cout<<"liu ";
			break;
		case 7:
			cout<<"qi ";
			break;
		case 8:
			cout<<"ba ";
			break;
		case 9:
			cout<<"jiu ";
			break;
		case 0:
			cout<<"ling ";
			break;
	}
    }
	return 0;
} 

#include<stdio.h>  
#include<string.h>  
#include <stdlib.h>   
void print_sum(int n){  
    char *name[] ={"ling","yi","er","san","si","wu","liu","qi","ba","jiu","shi"};  
    int a[10];  
    int i=0;  
    for(i=0;n>=10;i++){  
        a[i]=n%10;  
        n=n/10;  
    }  
     a[i++]=n;  
  
 while(i--){  
    if(i!=0){  
      printf("%s ",name[a[i]]);  
    }else{  
    printf("%s\n",name[a[i]]);  
    }  
  }  
  
      
}  
int main(){  
    char s[100];  
    char *n=s;  
    scanf("%s",s);  
    int sum=0;  
    while(*n!='\0'){  
        sum=sum+(*n-'0');  
        n++;  
    }  
    print_sum(sum);  
}  


### 关于PAT基础级别练习的相关C++资料或题目 对于 PAT (Programming Ability Test) 基础级别的练习,通常涉及一些基本的数据结构、算法以及编程技巧的应用。以下是关于如何获取相关资源和解决方法的一些指导: #### 资源推荐 可以参考在线平台上的公开教程或者书籍来学习 C++ 编程的基础知识及其应用到 PAT 的解题思路中[^1]。例如,《A Practical Approach to Computer Systems Design and Architecture》一书中提到的设计模式概念可以帮助开发者更好地理解软件系统的灵活性和可维护性设计原则[^2]。 虽然该书主要讨论的是计算机系统架构方面的内容,但是其中所提及的对象导向思维同样适用于编写高效且易于管理的程序代码——这正是参加像 PAT 这样的考试所需要具备的能力之一。 #### 解决方案示例 下面给出一个简单的例子展示如何利用面向对象的思想解决问题并提供相应解答: 假设我们遇到这样一个问题:“给定两个整数a,b求它们的最大公约数。” ```cpp #include <iostream> using namespace std; class GCD { public: static int compute(int a, int b){ while(b != 0){ int temp = b; b = a % b; a = temp; } return abs(a); } }; int main(){ cout << "Enter two integers: "; int num1,num2; cin>>num1>>num2; cout<<"Greatest Common Divisor is "<<GCD::compute(num1,num2)<<endl; } ``` 此段代码定义了一个名为 `GCD` 的类用于计算最大公因数,并通过静态成员函数实现功能调用无需实例化即可完成操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值