我正在做一項作業,我需要創建一個程式來讀取一個非空的整數序列,并告訴其中有多少與最后一個相等。
它應該讀取序列具有的整數數量,然后讀取序列本身并回傳最后一個數字重復的次數,不包括最后一個。
輸入將是這樣的:
9
1 7 3 2 4 7 5 8 7
并且輸出應該是:
2
現在,我對程式的功能沒有任何問題,但我正在努力讓它讀取輸入。這是我得到的:
#include <iostream>
#include <vector>
#include <sstream>
int NumbersEqualToLast(int limit, std::vector<int> elements) {
int check = elements[limit], counter = 0;
for (int i = limit; i >= 0; i--) {
if (elements[i] == check) {
counter ;
}
}
return(counter);
}
int main() {
int amount, number;
std::cin >> amount;
std::string input;
getline(std::cin, input);
std::stringstream iss(input);
std::vector<int> numbers;
while ( iss >> number ) {
numbers.push_back( number );
}
std::cout << NumbersEqualToLast(amount, numbers) << std::endl;
}
問題是在讀取了整數數量(在本例中為 9)后,我收到了 Segmentation fault (core dumped) 錯誤。
解決后編輯
這就是使用您的建議對我有用的方法。謝謝你。我知道它是否不漂亮或者有更好更有效的方法,但我才剛剛開始。:)
#include <iostream>
#include <vector>
int NumbersEqualToLast(int limit, std::vector<int> elements) {
int check = elements[limit - 1], counter = 0;
for (int i = limit - 2; i >= 0; i--) {
if (elements[i] == check) {
counter ;
}
}
return(counter);
}
int main() {
int quantity;
std::cin >> quantity;
int number;
std::vector<int> numbers;
for (int i = 0; i < quantity; i ) {
std::cin>>number;
numbers.push_back(number);
}
std::cout << NumbersEqualToLast(quantity, numbers) << std::endl;
}
uj5u.com熱心網友回復:
只是不要苛刻地判斷,請。我建議另一種方法來解決這個問題。
#include <iostream>
#include <vector>
using namespace std;
int special, count;
void dfs(int current, int previous, vector<int>& visited, vector<int>& input)
{
if(visited[current]==1)
{
return;
}
visited[current]=1;
if(current==(input.size()-1))
{
special=input[current];
}
for(int next=(current 1); next<input.size(); next)
{
if(next==previous)
{
continue;
}
dfs(next, current, visited, input);
}
if(special==input[current])
{
count;
}
if(current==0)
{
--count;
cout<<count;
}
return;
}
void solve()
{
int quantity;
cin>>quantity;
int number;
vector<int> numbers;
for(int i=0; i<quantity; i)
{
cin>>number;
numbers.push_back(number);
}
vector<int> visited(quantity);
dfs(0, -1, visited, numbers);
return;
}
int main()
{
solve();
return 0;
}
輸入:
9
1 7 3 2 4 7 5 8 7
結果如下:
2
轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/367111.html
