質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

Q&A

解決済

1回答

698閲覧

AtCoder の問題を解いてる際に生じたエラーについて

PINE1103

総合スコア20

アルゴリズム

アルゴリズムとは、定められた目的を達成するために、プログラムの理論的な動作を定義するものです。

C++

C++はC言語をもとにしてつくられた最もよく使われるマルチパラダイムプログラミング言語の1つです。オブジェクト指向、ジェネリック、命令型など広く対応しており、多目的に使用されています。

0グッド

0クリップ

投稿2020/08/26 04:24

編集2020/08/26 05:12

https://atcoder.jp/contests/abc161/tasks/abc161_d
にある問題を解いていたのですが、再帰関数を用いた実装でエラーとなってしまいました。
エラーとなった実装は1番目のコードです。このコードの中のketa++というところを、少し変えると解決したのですが(2番目のコード)自分でも理由がよくわかりませんでした。原因がわかる方がいらっしゃればお聞きしたいです。

c++

1#include <bits/stdc++.h> 2using namespace std; 3typedef long long ll; 4typedef long double ld; 5typedef pair<int, int> P; 6const ll mod = 1000000007; 7const ll INF = 1e+14; 8#define rep(i,n) for(int i=0;i<n;i++) 9#define per(i,n) for(int i=n-1;i>=0;i--) 10#define Rep(i,sta,n) for(int i=sta;i<n;i++) 11#define rep1(i,n) for(int i=1;i<=n;i++) 12#define per1(i,n) for(int i=n;i>=1;i--) 13#define Rep1(i,sta,n) for(int i=sta;i<=n;i++) 14#define _GLIBCXX_DEBUG 15 16 17void dfs (ll keta , ll n , vector<ll> &a){ 18 if(keta==11){ 19 return; 20 } 21 22 a.push_back(n); 23 for(int i=-1;i<2;i++){ 24 int res=n%10; 25 if(res+i>=0&&res+i<=9) { 26 keta++; 27 dfs(keta,n*10+res+i,a); 28 } 29 } 30} 31 32int main(){ 33 int k; 34 cin>>k; 35 vector<ll> a; 36 rep1(i,9){ 37 dfs(1,i,a); 38 } 39 sort(a.begin(),a.end()); 40 cout<<a[k-1]<<endl; 41} 42

c++

1#include <bits/stdc++.h> 2using namespace std; 3typedef long long ll; 4typedef long double ld; 5typedef pair<int, int> P; 6const ll mod = 1000000007; 7const ll INF = 1e+14; 8#define rep(i,n) for(int i=0;i<n;i++) 9#define per(i,n) for(int i=n-1;i>=0;i--) 10#define Rep(i,sta,n) for(int i=sta;i<n;i++) 11#define rep1(i,n) for(int i=1;i<=n;i++) 12#define per1(i,n) for(int i=n;i>=1;i--) 13#define Rep1(i,sta,n) for(int i=sta;i<=n;i++) 14#define _GLIBCXX_DEBUG 15 16 17void dfs (ll keta , ll n , vector<ll> &a){ 18 if(keta==11){ 19 return; 20 } 21 22 a.push_back(n); 23 for(int i=-1;i<2;i++){ 24 int res=n%10; 25 if(res+i>=0&&res+i<=9) { 26 dfs(keta+1,n*10+res+i,a); 27 } 28 } 29} 30 31int main(){ 32 int k; 33 cin>>k; 34 vector<ll> a; 35 rep1(i,9){ 36 dfs(1,i,a); 37 } 38 sort(a.begin(),a.end()); 39 cout<<a[k-1]<<endl; 40} 41

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

m.ts10806

2020/08/26 04:31

>再起関数を 「再帰」だと思います。
PINE1103

2020/08/26 05:12

失礼いたしました。訂正しました。
guest

回答1

0

ベストアンサー

最初のコードでエラーになるのはketaが12以上で呼び出されるパターンがあるからです。
そうなると実質最初のreturnが実行されることは無いので、無限に再帰呼び出しされます。

投稿2020/08/26 04:37

yudedako67

総合スコア2047

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

PINE1103

2020/08/26 05:15 編集

なるほど、for文のところで2回もしくは3回ketaが更新される場合があるので12以上に成り得るということで合っていますでしょうか?
PINE1103

2020/08/26 05:19

回答ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問