Total Decoding Messages Python
PROGRAM TO COUNT POSSIBLE DECODINGS OF A GIVEN DIGIT SEQUENCE
OUTPUT:
Count is 3
# A Dynamic Programming based function
# to count decodings
def
countDecodingDP(digits, n):
count
=
[
0
]
*
(n
+
1
);
# A table to store
# results of subproblems
count[
0
]
=
1
;
count[
1
]
=
1
;
for
i
in
range
(
2
, n
+
1
):
count[i]
=
0
;
# If the last digit is not 0, then last
# digit must add to the number of words
if
(digits[i
-
1
] >
'0'
):
count[i]
=
count[i
-
1
];
# If second last digit is smaller than 2
# and last digit is smaller than 7, then
# last two digits form a valid character
if
(digits[i
-
2
]
=
=
'1'
or
(digits[i
-
2
]
=
=
'2'
and
digits[i
-
1
] <
'7'
) ):
count[i]
+
=
count[i
-
2
];
return
count[n];
# Driver Code
digits
=
"1234"
;
n
=
len
(digits);
print
(
"Count is"
,
countDecodingDP(digits, n));
Count is 3
Comments
Post a Comment