PTA 数列求和加强版
2016-04-04 17:11
721 查看
PTA编程题:
5-38 数列求和-加强版 (20分)
给定某数字AA(1\le
A\le 91≤A≤9)以及非负整数NN(0\le
N\le 1000000≤N≤100000),求数列之和S
= A + AA + AAA + \cdots + AA\cdots AS=A+AA+AAA+⋯+AA⋯A(NN个AA)。例如A=1A=1, N=3N=3时,S
= 1 + 11 + 111 = 123S=1+11+111=123。
这道题不能简单的用数类型来运算,因为N太大,即使long long型也存不下,所以用数组来存放和运算。
代码如下:
#include<iostream>
using namespace std;
int arr[200000] = { 0 }; //用数组来存放数,并实现进位和输出;
int main(){
int a, n,A,j=0,size=0;
cin >> a >> n;
if (n != 0)
{
for (int i = 0; i < n; i++)
{
arr[i] = (n - i)*a; //每一位先存放一个运算的结果
}
while (arr[j] != 0) //进行进位运算
{
A = arr[j] % 10;
arr[j + 1] = arr[j] / 10 + arr[j + 1];
arr[j] = A;
j++;
}
for (int i = j - 1; i >= 0; i--)
{
cout << arr[i];
}
}
else
cout << 0;
return 0;
}
5-38 数列求和-加强版 (20分)
给定某数字AA(1\le
A\le 91≤A≤9)以及非负整数NN(0\le
N\le 1000000≤N≤100000),求数列之和S
= A + AA + AAA + \cdots + AA\cdots AS=A+AA+AAA+⋯+AA⋯A(NN个AA)。例如A=1A=1, N=3N=3时,S
= 1 + 11 + 111 = 123S=1+11+111=123。
输入格式:
输入数字AA与非负整数NN。输出格式:
输出其NN项数列之和SS的值。输入样例:
1 3
输出样例:
123
这道题不能简单的用数类型来运算,因为N太大,即使long long型也存不下,所以用数组来存放和运算。
代码如下:
#include<iostream>
using namespace std;
int arr[200000] = { 0 }; //用数组来存放数,并实现进位和输出;
int main(){
int a, n,A,j=0,size=0;
cin >> a >> n;
if (n != 0)
{
for (int i = 0; i < n; i++)
{
arr[i] = (n - i)*a; //每一位先存放一个运算的结果
}
while (arr[j] != 0) //进行进位运算
{
A = arr[j] % 10;
arr[j + 1] = arr[j] / 10 + arr[j + 1];
arr[j] = A;
j++;
}
for (int i = j - 1; i >= 0; i--)
{
cout << arr[i];
}
}
else
cout << 0;
return 0;
}
相关文章推荐
- Chessboard(HDU1838)
- 获取系统信息
- 在线编程--生成窗口最大值数组
- 实现点击按钮切换显示和隐藏效果
- hibernate 4 映射组件属性 自定义类型
- http常见状态码
- POJ 3107 Godfather(树形DP)
- 获取系统的当前信息
- SOLR在电商中的基本应用
- hadoop 学习自定义排序
- 3.29课·········表单验证和事件
- 在Action中访问WEB资源
- 获取文件数组和文件夹数组
- java下载文件
- Android 双击back键退出应用的两种方式
- 杭电1548
- 伪币识别问题
- LVM
- hdu1434(优先队列&&模拟)
- LeetCode-24.Swap Nodes in Pairs